tqSink.c 16.4 KB
Newer Older
L
Liu Jicong 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

16 17
#include "tcommon.h"
#include "tmsg.h"
L
Liu Jicong 已提交
18 19
#include "tq.h"

H
Haojun Liao 已提交
20 21 22
int32_t tqBuildDeleteReq(const char* stbFullName, const SSDataBlock* pDataBlock, SBatchDeleteReq* deleteReq,
                         const char* pIdStr) {
  int32_t          totalRows = pDataBlock->info.rows;
L
Liu Jicong 已提交
23 24
  SColumnInfoData* pStartTsCol = taosArrayGet(pDataBlock->pDataBlock, START_TS_COLUMN_INDEX);
  SColumnInfoData* pEndTsCol = taosArrayGet(pDataBlock->pDataBlock, END_TS_COLUMN_INDEX);
25
  SColumnInfoData* pGidCol = taosArrayGet(pDataBlock->pDataBlock, GROUPID_COLUMN_INDEX);
26 27
  SColumnInfoData* pTbNameCol = taosArrayGet(pDataBlock->pDataBlock, TABLE_NAME_COLUMN_INDEX);

H
Haojun Liao 已提交
28
  tqDebug("s-task:%s build %d rows delete msg for table:%s", pIdStr, totalRows, stbFullName);
29

H
Haojun Liao 已提交
30 31 32
  for (int32_t row = 0; row < totalRows; row++) {
    int64_t skey = *(int64_t*)colDataGetData(pStartTsCol, row);
    int64_t ekey = *(int64_t*)colDataGetData(pEndTsCol, row);
33
    int64_t groupId = *(int64_t*)colDataGetData(pGidCol, row);
H
Haojun Liao 已提交
34

35
    char*   name;
36
    void*   varTbName = NULL;
H
Haojun Liao 已提交
37
    if (!colDataIsNull(pTbNameCol, totalRows, row, NULL)) {
38 39 40
      varTbName = colDataGetVarData(pTbNameCol, row);
    }

41 42 43 44 45 46
    if (varTbName != NULL && varTbName != (void*)-1) {
      name = taosMemoryCalloc(1, TSDB_TABLE_NAME_LEN);
      memcpy(name, varDataVal(varTbName), varDataLen(varTbName));
    } else {
      name = buildCtbNameByGroupId(stbFullName, groupId);
    }
47

H
Haojun Liao 已提交
48 49 50 51
    tqDebug("s-task:%s build delete msg groupId:%" PRId64 ", name:%s, skey:%" PRId64 " ekey:%" PRId64,
            pIdStr, groupId, name, skey, ekey);

    SSingleDeleteReq req = { .startTs = skey, .endTs = ekey};
L
Liu Jicong 已提交
52
    strncpy(req.tbname, name, TSDB_TABLE_NAME_LEN - 1);
53
    taosMemoryFree(name);
H
Haojun Liao 已提交
54

55 56
    taosArrayPush(deleteReq->deleteReqs, &req);
  }
H
Haojun Liao 已提交
57

58 59 60
  return 0;
}

61
static int32_t encodeCreateChildTableForRPC(SVCreateTbBatchReq* pReqs, int32_t vgId, void** pBuf, int32_t* contLen) {
62
  int32_t ret = 0;
5
54liuyao 已提交
63

64
  tEncodeSize(tEncodeSVCreateTbBatchReq, pReqs, *contLen, ret);
5
54liuyao 已提交
65 66 67 68 69 70 71 72 73 74 75 76 77
  if (ret < 0) {
    ret = -1;
    goto end;
  }
  *contLen += sizeof(SMsgHead);
  *pBuf = rpcMallocCont(*contLen);
  if (NULL == *pBuf) {
    ret = -1;
    goto end;
  }
  ((SMsgHead*)(*pBuf))->vgId = vgId;
  ((SMsgHead*)(*pBuf))->contLen = htonl(*contLen);
  SEncoder coder = {0};
78
  tEncoderInit(&coder, POINTER_SHIFT(*pBuf, sizeof(SMsgHead)), (*contLen) - sizeof(SMsgHead));
79
  if (tEncodeSVCreateTbBatchReq(&coder, pReqs) < 0) {
5
54liuyao 已提交
80 81 82 83 84 85 86 87 88 89 90 91 92
    rpcFreeCont(*pBuf);
    *pBuf = NULL;
    *contLen = 0;
    tEncoderClear(&coder);
    ret = -1;
    goto end;
  }
  tEncoderClear(&coder);

end:
  return ret;
}

93
int32_t tqPutReqToQueue(SVnode* pVnode, SVCreateTbBatchReq* pReqs) {
5
54liuyao 已提交
94 95
  void*   buf = NULL;
  int32_t tlen = 0;
96
  encodeCreateChildTableForRPC(pReqs, TD_VID(pVnode), &buf, &tlen);
5
54liuyao 已提交
97

H
Haojun Liao 已提交
98
  SRpcMsg msg = { .msgType = TDMT_VND_CREATE_TABLE, .pCont = buf, .contLen = tlen };
5
54liuyao 已提交
99 100 101 102 103 104
  if (tmsgPutToQueue(&pVnode->msgCb, WRITE_QUEUE, &msg) != 0) {
    tqError("failed to put into write-queue since %s", terrstr());
  }

  return TSDB_CODE_SUCCESS;
}
105

H
Haojun Liao 已提交
106
void tqSinkToTablePipeline(SStreamTask* pTask, void* vnode, int64_t ver, void* data) {
L
Liu Jicong 已提交
107 108 109 110 111
  const SArray* pBlocks = (const SArray*)data;
  SVnode*       pVnode = (SVnode*)vnode;
  int64_t       suid = pTask->tbSink.stbUid;
  char*         stbFullName = pTask->tbSink.stbFullName;
  STSchema*     pTSchema = pTask->tbSink.pTSchema;
L
Liu Jicong 已提交
112 113 114

  int32_t blockSz = taosArrayGetSize(pBlocks);

115
  tqDebug("vgId:%d, s-task:%s write results blocks:%d into table", TD_VID(pVnode), pTask->id.idStr, blockSz);
L
Liu Jicong 已提交
116

L
Liu Jicong 已提交
117 118 119
  void*   pBuf = NULL;
  SArray* tagArray = NULL;
  SArray* pVals = NULL;
120
  SArray* crTblArray = NULL;
L
Liu Jicong 已提交
121 122 123

  for (int32_t i = 0; i < blockSz; i++) {
    SSDataBlock* pDataBlock = taosArrayGet(pBlocks, i);
5
54liuyao 已提交
124
    int32_t      rows = pDataBlock->info.rows;
H
Haojun Liao 已提交
125

L
Liu Jicong 已提交
126
    if (pDataBlock->info.type == STREAM_DELETE_RESULT) {
H
Haojun Liao 已提交
127 128 129
      SBatchDeleteReq deleteReq = {.suid = suid, .deleteReqs = taosArrayInit(0, sizeof(SSingleDeleteReq))};

      tqBuildDeleteReq(stbFullName, pDataBlock, &deleteReq, pTask->id.idStr);
L
Liu Jicong 已提交
130 131 132 133 134 135 136 137
      if (taosArrayGetSize(deleteReq.deleteReqs) == 0) {
        taosArrayDestroy(deleteReq.deleteReqs);
        continue;
      }

      int32_t len;
      int32_t code;
      tEncodeSize(tEncodeSBatchDeleteReq, &deleteReq, len, code);
H
Haojun Liao 已提交
138 139
      if (code != TSDB_CODE_SUCCESS) {
        qError("s-task:%s failed to encode delete request", pTask->id.idStr);
L
Liu Jicong 已提交
140
      }
H
Haojun Liao 已提交
141

L
Liu Jicong 已提交
142 143 144 145 146 147 148 149 150 151
      SEncoder encoder;
      void*    serializedDeleteReq = rpcMallocCont(len + sizeof(SMsgHead));
      void*    abuf = POINTER_SHIFT(serializedDeleteReq, sizeof(SMsgHead));
      tEncoderInit(&encoder, abuf, len);
      tEncodeSBatchDeleteReq(&encoder, &deleteReq);
      tEncoderClear(&encoder);
      taosArrayDestroy(deleteReq.deleteReqs);

      ((SMsgHead*)serializedDeleteReq)->vgId = pVnode->config.vgId;

H
Haojun Liao 已提交
152
      SRpcMsg msg = { .msgType = TDMT_VND_BATCH_DEL, .pCont = serializedDeleteReq, .contLen = len + sizeof(SMsgHead) };
L
Liu Jicong 已提交
153 154 155
      if (tmsgPutToQueue(&pVnode->msgCb, WRITE_QUEUE, &msg) != 0) {
        tqDebug("failed to put delete req into write-queue since %s", terrstr());
      }
5
54liuyao 已提交
156
    } else if (pDataBlock->info.type == STREAM_CREATE_CHILD_TABLE) {
157 158 159 160 161
      SVCreateTbBatchReq reqs = {0};
      crTblArray = reqs.pArray = taosArrayInit(1, sizeof(struct SVCreateTbReq));
      if (NULL == reqs.pArray) {
        goto _end;
      }
H
Haojun Liao 已提交
162

5
54liuyao 已提交
163
      for (int32_t rowId = 0; rowId < rows; rowId++) {
164
        SVCreateTbReq  createTbReq = {0};
165
        SVCreateTbReq* pCreateTbReq = &createTbReq;
5
54liuyao 已提交
166 167 168 169 170 171 172 173 174

        // set const
        pCreateTbReq->flags = 0;
        pCreateTbReq->type = TSDB_CHILD_TABLE;
        pCreateTbReq->ctb.suid = suid;

        // set super table name
        SName name = {0};
        tNameFromString(&name, stbFullName, T_NAME_ACCT | T_NAME_DB | T_NAME_TABLE);
175
        pCreateTbReq->ctb.stbName = taosStrdup((char*)tNameGetTableName(&name));  // taosStrdup(stbFullName);
5
54liuyao 已提交
176 177 178 179 180 181

        // set tag content
        int32_t size = taosArrayGetSize(pDataBlock->pDataBlock);
        if (size == 2) {
          tagArray = taosArrayInit(1, sizeof(STagVal));
          if (!tagArray) {
wmmhello's avatar
wmmhello 已提交
182
            tdDestroySVCreateTbReq(pCreateTbReq);
5
54liuyao 已提交
183 184
            goto _end;
          }
H
Haojun Liao 已提交
185

5
54liuyao 已提交
186 187 188 189 190
          STagVal tagVal = {
              .cid = pTSchema->numOfCols + 1,
              .type = TSDB_DATA_TYPE_UBIGINT,
              .i64 = (int64_t)pDataBlock->info.id.groupId,
          };
H
Haojun Liao 已提交
191

5
54liuyao 已提交
192 193 194 195 196 197 198 199 200 201
          taosArrayPush(tagArray, &tagVal);

          // set tag name
          SArray* tagName = taosArrayInit(1, TSDB_COL_NAME_LEN);
          char    tagNameStr[TSDB_COL_NAME_LEN] = "group_id";
          taosArrayPush(tagName, tagNameStr);
          pCreateTbReq->ctb.tagName = tagName;
        } else {
          tagArray = taosArrayInit(size - 1, sizeof(STagVal));
          if (!tagArray) {
wmmhello's avatar
wmmhello 已提交
202
            tdDestroySVCreateTbReq(pCreateTbReq);
5
54liuyao 已提交
203 204 205 206
            goto _end;
          }
          for (int32_t tagId = UD_TAG_COLUMN_INDEX, step = 1; tagId < size; tagId++, step++) {
            SColumnInfoData* pTagData = taosArrayGet(pDataBlock->pDataBlock, tagId);
207 208 209

            STagVal tagVal = {.cid = pTSchema->numOfCols + step, .type = pTagData->info.type};
            void*   pData = colDataGetData(pTagData, rowId);
5
54liuyao 已提交
210
            if (colDataIsNull_s(pTagData, rowId)) {
5
54liuyao 已提交
211
              continue;
5
54liuyao 已提交
212 213 214 215 216 217 218 219 220
            } else if (IS_VAR_DATA_TYPE(pTagData->info.type)) {
              tagVal.nData = varDataLen(pData);
              tagVal.pData = varDataVal(pData);
            } else {
              memcpy(&tagVal.i64, pData, pTagData->info.bytes);
            }
            taosArrayPush(tagArray, &tagVal);
          }
        }
5
54liuyao 已提交
221
        pCreateTbReq->ctb.tagNum = TMAX(size - UD_TAG_COLUMN_INDEX, 1);
5
54liuyao 已提交
222 223 224 225 226

        STag* pTag = NULL;
        tTagNew(tagArray, 1, false, &pTag);
        tagArray = taosArrayDestroy(tagArray);
        if (pTag == NULL) {
wmmhello's avatar
wmmhello 已提交
227
          tdDestroySVCreateTbReq(pCreateTbReq);
5
54liuyao 已提交
228 229 230
          terrno = TSDB_CODE_OUT_OF_MEMORY;
          goto _end;
        }
231

232

5
54liuyao 已提交
233 234 235
        pCreateTbReq->ctb.pTag = (uint8_t*)pTag;

        // set table name
5
54liuyao 已提交
236
        if (!pDataBlock->info.parTbName[0]) {
5
54liuyao 已提交
237
          SColumnInfoData* pGpIdColInfo = taosArrayGet(pDataBlock->pDataBlock, UD_GROUPID_COLUMN_INDEX);
238
          void*            pGpIdData = colDataGetData(pGpIdColInfo, rowId);
5
54liuyao 已提交
239 240
          pCreateTbReq->name = buildCtbNameByGroupId(stbFullName, *(uint64_t*)pGpIdData);
        } else {
241
          pCreateTbReq->name = taosStrdup(pDataBlock->info.parTbName);
5
54liuyao 已提交
242
        }
243
        taosArrayPush(reqs.pArray, pCreateTbReq);
5
54liuyao 已提交
244
      }
245 246 247 248 249 250 251
      reqs.nReqs = taosArrayGetSize(reqs.pArray);
      if (tqPutReqToQueue(pVnode, &reqs) != TSDB_CODE_SUCCESS) {
        goto _end;
      }
      tagArray = taosArrayDestroy(tagArray);
      taosArrayDestroyEx(crTblArray, (FDelete)tdDestroySVCreateTbReq);
      crTblArray = NULL;
L
Liu Jicong 已提交
252
    } else {
L
Liu Jicong 已提交
253
      SSubmitTbData tbData = {0};
H
Haojun Liao 已提交
254
      tqDebug("tq sink pipe, convert block1 %d, rows: %d", i, rows);
L
Liu Jicong 已提交
255 256

      if (!(tbData.aRowP = taosArrayInit(rows, sizeof(SRow*)))) {
L
Liu Jicong 已提交
257 258
        goto _end;
      }
L
Liu Jicong 已提交
259 260 261 262 263 264

      tbData.suid = suid;
      tbData.uid = 0;  // uid is assigned by vnode
      tbData.sver = pTSchema->version;

      char* ctbName = NULL;
5
54liuyao 已提交
265
      tqDebug("vgId:%d, stream write into %s, table auto created", TD_VID(pVnode), pDataBlock->info.parTbName);
L
Liu Jicong 已提交
266
      if (pDataBlock->info.parTbName[0]) {
267
        ctbName = taosStrdup(pDataBlock->info.parTbName);
L
Liu Jicong 已提交
268 269 270 271 272 273 274 275 276 277
      } else {
        ctbName = buildCtbNameByGroupId(stbFullName, pDataBlock->info.id.groupId);
      }

      SMetaReader mr = {0};
      metaReaderInit(&mr, pVnode->pMeta, 0);
      if (metaGetTableEntryByName(&mr, ctbName) < 0) {
        metaReaderClear(&mr);
        tqDebug("vgId:%d, stream write into %s, table auto created", TD_VID(pVnode), ctbName);

L
Liu Jicong 已提交
278
        SVCreateTbReq* pCreateTbReq = NULL;
L
Liu Jicong 已提交
279

L
Liu Jicong 已提交
280
        if (!(pCreateTbReq = taosMemoryCalloc(1, sizeof(SVCreateStbReq)))) {
wmmhello's avatar
wmmhello 已提交
281
          taosMemoryFree(ctbName);
L
Liu Jicong 已提交
282 283 284 285 286 287 288 289 290 291 292
          goto _end;
        };

        // set const
        pCreateTbReq->flags = 0;
        pCreateTbReq->type = TSDB_CHILD_TABLE;
        pCreateTbReq->ctb.suid = suid;

        // set super table name
        SName name = {0};
        tNameFromString(&name, stbFullName, T_NAME_ACCT | T_NAME_DB | T_NAME_TABLE);
293
        pCreateTbReq->ctb.stbName = taosStrdup((char*)tNameGetTableName(&name));  // taosStrdup(stbFullName);
L
Liu Jicong 已提交
294 295

        // set tag content
5
54liuyao 已提交
296 297
        tagArray = taosArrayInit(1, sizeof(STagVal));
        if (!tagArray) {
wmmhello's avatar
wmmhello 已提交
298 299
          taosMemoryFree(ctbName);
          tdDestroySVCreateTbReq(pCreateTbReq);
5
54liuyao 已提交
300 301
          goto _end;
        }
L
Liu Jicong 已提交
302
        STagVal tagVal = {
303
            .cid = pTSchema->numOfCols + 1,
L
Liu Jicong 已提交
304 305 306 307 308 309 310 311
            .type = TSDB_DATA_TYPE_UBIGINT,
            .i64 = (int64_t)pDataBlock->info.id.groupId,
        };
        taosArrayPush(tagArray, &tagVal);
        pCreateTbReq->ctb.tagNum = taosArrayGetSize(tagArray);

        STag* pTag = NULL;
        tTagNew(tagArray, 1, false, &pTag);
5
54liuyao 已提交
312
        tagArray = taosArrayDestroy(tagArray);
L
Liu Jicong 已提交
313
        if (pTag == NULL) {
D
dapan1121 已提交
314 315
          taosMemoryFree(ctbName);
          tdDestroySVCreateTbReq(pCreateTbReq);
L
Liu Jicong 已提交
316
          terrno = TSDB_CODE_OUT_OF_MEMORY;
wmmhello's avatar
wmmhello 已提交
317 318
          taosMemoryFree(ctbName);
          tdDestroySVCreateTbReq(pCreateTbReq);
L
Liu Jicong 已提交
319
          goto _end;
L
Liu Jicong 已提交
320
        }
L
Liu Jicong 已提交
321
        pCreateTbReq->ctb.pTag = (uint8_t*)pTag;
L
Liu Jicong 已提交
322

L
Liu Jicong 已提交
323 324 325 326 327 328
        // set tag name
        SArray* tagName = taosArrayInit(1, TSDB_COL_NAME_LEN);
        char    tagNameStr[TSDB_COL_NAME_LEN] = {0};
        strcpy(tagNameStr, "group_id");
        taosArrayPush(tagName, tagNameStr);
        pCreateTbReq->ctb.tagName = tagName;
L
Liu Jicong 已提交
329

L
Liu Jicong 已提交
330
        // set table name
L
Liu Jicong 已提交
331 332
        pCreateTbReq->name = ctbName;
        ctbName = NULL;
L
Liu Jicong 已提交
333

L
Liu Jicong 已提交
334 335 336 337 338 339 340 341 342 343
        tbData.pCreateTbReq = pCreateTbReq;
        tbData.flags = SUBMIT_REQ_AUTO_CREATE_TABLE;
      } else {
        if (mr.me.type != TSDB_CHILD_TABLE) {
          tqError("vgId:%d, failed to write into %s, since table type incorrect, type %d", TD_VID(pVnode), ctbName,
                  mr.me.type);
          metaReaderClear(&mr);
          taosMemoryFree(ctbName);
          continue;
        }
L
Liu Jicong 已提交
344

L
Liu Jicong 已提交
345 346 347 348 349 350
        if (mr.me.ctbEntry.suid != suid) {
          tqError("vgId:%d, failed to write into %s, since suid mismatch, expect suid: %" PRId64
                  ", actual suid %" PRId64 "",
                  TD_VID(pVnode), ctbName, suid, mr.me.ctbEntry.suid);
          metaReaderClear(&mr);
          taosMemoryFree(ctbName);
5
54liuyao 已提交
351
          continue;
L
Liu Jicong 已提交
352
        }
L
Liu Jicong 已提交
353

L
Liu Jicong 已提交
354 355 356
        tbData.uid = mr.me.uid;
        metaReaderClear(&mr);
        taosMemoryFreeClear(ctbName);
L
Liu Jicong 已提交
357 358
      }

L
Liu Jicong 已提交
359
      // rows
L
Liu Jicong 已提交
360
      if (!pVals && !(pVals = taosArrayInit(pTSchema->numOfCols, sizeof(SColVal)))) {
L
Liu Jicong 已提交
361
        taosArrayDestroy(tbData.aRowP);
wmmhello's avatar
wmmhello 已提交
362
        tdDestroySVCreateTbReq(tbData.pCreateTbReq);
L
Liu Jicong 已提交
363 364 365 366 367
        goto _end;
      }

      for (int32_t j = 0; j < rows; j++) {
        taosArrayClear(pVals);
368
        int32_t dataIndex = 0;
L
Liu Jicong 已提交
369
        for (int32_t k = 0; k < pTSchema->numOfCols; k++) {
370
          const STColumn* pCol = &pTSchema->columns[k];
L
Liu Jicong 已提交
371
          if (k == 0) {
372
            SColumnInfoData* pColData = taosArrayGet(pDataBlock->pDataBlock, dataIndex);
373
            void*            colData = colDataGetData(pColData, j);
L
Liu Jicong 已提交
374 375
            tqDebug("tq sink pipe2, row %d, col %d ts %" PRId64, j, k, *(int64_t*)colData);
          }
376
          if (IS_SET_NULL(pCol)) {
L
Liu Jicong 已提交
377 378
            SColVal cv = COL_VAL_NULL(pCol->colId, pCol->type);
            taosArrayPush(pVals, &cv);
379
          } else {
380 381 382
            SColumnInfoData* pColData = taosArrayGet(pDataBlock->pDataBlock, dataIndex);
            if (colDataIsNull_s(pColData, j)) {
              SColVal cv = COL_VAL_NULL(pCol->colId, pCol->type);
L
Liu Jicong 已提交
383
              taosArrayPush(pVals, &cv);
384
              dataIndex++;
L
Liu Jicong 已提交
385
            } else {
386 387
              void* colData = colDataGetData(pColData, j);
              if (IS_STR_DATA_TYPE(pCol->type)) {
H
Haojun Liao 已提交
388 389
                // address copy, no value
                SValue  sv = (SValue){.nData = varDataLen(colData), .pData = varDataVal(colData)};
390 391 392 393 394 395 396 397 398
                SColVal cv = COL_VAL_VALUE(pCol->colId, pCol->type, sv);
                taosArrayPush(pVals, &cv);
              } else {
                SValue sv;
                memcpy(&sv.val, colData, tDataTypes[pCol->type].bytes);
                SColVal cv = COL_VAL_VALUE(pCol->colId, pCol->type, sv);
                taosArrayPush(pVals, &cv);
              }
              dataIndex++;
L
Liu Jicong 已提交
399 400 401 402 403
            }
          }
        }
        SRow* pRow = NULL;
        if ((terrno = tRowBuild(pVals, (STSchema*)pTSchema, &pRow)) < 0) {
404
          tDestroySubmitTbData(&tbData, TSDB_MSG_FLG_ENCODE);
L
Liu Jicong 已提交
405 406 407
          goto _end;
        }
        ASSERT(pRow);
L
Liu Jicong 已提交
408
        taosArrayPush(tbData.aRowP, &pRow);
L
Liu Jicong 已提交
409 410
      }

L
Liu Jicong 已提交
411 412
      SSubmitReq2 submitReq = {0};
      if (!(submitReq.aSubmitTbData = taosArrayInit(1, sizeof(SSubmitTbData)))) {
413
        tDestroySubmitTbData(&tbData, TSDB_MSG_FLG_ENCODE);
L
Liu Jicong 已提交
414 415 416 417
        goto _end;
      }

      taosArrayPush(submitReq.aSubmitTbData, &tbData);
L
Liu Jicong 已提交
418 419

      // encode
L
Liu Jicong 已提交
420
      int32_t len;
L
Liu Jicong 已提交
421
      int32_t code;
422
      tEncodeSize(tEncodeSubmitReq, &submitReq, len, code);
L
Liu Jicong 已提交
423
      SEncoder encoder;
424
      len += sizeof(SSubmitReq2Msg);
L
Liu Jicong 已提交
425 426
      pBuf = rpcMallocCont(len);
      if (NULL == pBuf) {
427
        tDestroySubmitReq(&submitReq, TSDB_MSG_FLG_ENCODE);
L
Liu Jicong 已提交
428 429
        goto _end;
      }
430 431 432 433
      ((SSubmitReq2Msg*)pBuf)->header.vgId = TD_VID(pVnode);
      ((SSubmitReq2Msg*)pBuf)->header.contLen = htonl(len);
      ((SSubmitReq2Msg*)pBuf)->version = htobe64(1);
      tEncoderInit(&encoder, POINTER_SHIFT(pBuf, sizeof(SSubmitReq2Msg)), len - sizeof(SSubmitReq2Msg));
434
      if (tEncodeSubmitReq(&encoder, &submitReq) < 0) {
L
Liu Jicong 已提交
435 436
        terrno = TSDB_CODE_OUT_OF_MEMORY;
        tqError("failed to encode submit req since %s", terrstr());
L
Liu Jicong 已提交
437 438
        tEncoderClear(&encoder);
        rpcFreeCont(pBuf);
439
        tDestroySubmitReq(&submitReq, TSDB_MSG_FLG_ENCODE);
L
Liu Jicong 已提交
440
        continue;
L
Liu Jicong 已提交
441 442
      }
      tEncoderClear(&encoder);
443
      tDestroySubmitReq(&submitReq, TSDB_MSG_FLG_ENCODE);
L
Liu Jicong 已提交
444 445 446 447

      SRpcMsg msg = {
          .msgType = TDMT_VND_SUBMIT,
          .pCont = pBuf,
L
Liu Jicong 已提交
448
          .contLen = len,
L
Liu Jicong 已提交
449 450 451 452 453 454 455 456 457 458
      };

      if (tmsgPutToQueue(&pVnode->msgCb, WRITE_QUEUE, &msg) != 0) {
        tqDebug("failed to put into write-queue since %s", terrstr());
      }
    }
  }
_end:
  taosArrayDestroy(tagArray);
  taosArrayDestroy(pVals);
459
  taosArrayDestroyEx(crTblArray, (FDelete)tdDestroySVCreateTbReq);
L
Liu Jicong 已提交
460 461
  // TODO: change
}