472 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			472 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
| /*
 | |
|  * 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/>.
 | |
|  */
 | |
| 
 | |
| #define _DEFAULT_SOURCE
 | |
| #include "os.h"
 | |
| #include "taos.h"
 | |
| #include "taoserror.h"
 | |
| #include "tlog.h"
 | |
| 
 | |
| #define GREEN "\033[1;32m"
 | |
| #define NC "\033[0m"
 | |
| 
 | |
| char    dbName[32] = "db";
 | |
| char    stbName[64] = "st";
 | |
| int32_t numOfThreads = 1;
 | |
| int64_t numOfTables = 200000;
 | |
| int64_t startOffset = 0;
 | |
| int32_t createTable = 1;
 | |
| int32_t insertData = 0;
 | |
| int32_t batchNumOfTbl = 100;
 | |
| int32_t batchNumOfRow = 1;
 | |
| int32_t totalRowsOfPerTbl = 1;
 | |
| int32_t numOfVgroups = 2;
 | |
| int32_t showTablesFlag = 0;
 | |
| int32_t queryFlag = 0;
 | |
| 
 | |
| int64_t startTimestamp = 1640966400000;  // 2020-01-01 00:00:00.000
 | |
| 
 | |
| typedef struct {
 | |
|   int64_t   tableBeginIndex;
 | |
|   int64_t   tableEndIndex;
 | |
|   int32_t   threadIndex;
 | |
|   char      dbName[32];
 | |
|   char      stbName[64];
 | |
|   float     createTableSpeed;
 | |
|   float     insertDataSpeed;
 | |
|   int64_t   startMs;
 | |
|   int64_t   maxDelay;
 | |
|   int64_t   minDelay;
 | |
|   TdThread thread;
 | |
| } SThreadInfo;
 | |
| 
 | |
| // void  parseArgument(int32_t argc, char *argv[]);
 | |
| // void *threadFunc(void *param);
 | |
| // void  createDbAndStb();
 | |
| 
 | |
| void createDbAndStb() {
 | |
|   pPrint("start to create db and stable");
 | |
|   char qstr[64000];
 | |
| 
 | |
|   TAOS *con = taos_connect(NULL, "root", "taosdata", NULL, 0);
 | |
|   if (con == NULL) {
 | |
|     pError("failed to connect to DB, reason:%s", taos_errstr(NULL));
 | |
|     exit(1);
 | |
|   }
 | |
| 
 | |
|   sprintf(qstr, "create database if not exists %s vgroups %d", dbName, numOfVgroups);
 | |
|   TAOS_RES *pRes = taos_query(con, qstr);
 | |
|   int32_t   code = taos_errno(pRes);
 | |
|   if (code != 0) {
 | |
|     pError("failed to create database:%s, sql:%s, code:%d reason:%s", dbName, qstr, taos_errno(pRes),
 | |
|            taos_errstr(pRes));
 | |
|     exit(0);
 | |
|   }
 | |
|   taos_free_result(pRes);
 | |
| 
 | |
|   sprintf(qstr, "use %s", dbName);
 | |
|   pRes = taos_query(con, qstr);
 | |
|   code = taos_errno(pRes);
 | |
|   if (code != 0) {
 | |
|     pError("failed to use db, code:%d reason:%s", taos_errno(pRes), taos_errstr(pRes));
 | |
|     exit(0);
 | |
|   }
 | |
|   taos_free_result(pRes);
 | |
| 
 | |
|   sprintf(qstr, "create table if not exists %s (ts timestamp, i int) tags (j bigint)", stbName);
 | |
|   pRes = taos_query(con, qstr);
 | |
|   code = taos_errno(pRes);
 | |
|   if (code != 0) {
 | |
|     pError("failed to create stable, code:%d reason:%s", taos_errno(pRes), taos_errstr(pRes));
 | |
|     exit(0);
 | |
|   }
 | |
|   taos_free_result(pRes);
 | |
| 
 | |
|   taos_close(con);
 | |
| }
 | |
| 
 | |
| void printCreateProgress(SThreadInfo *pInfo, int64_t t) {
 | |
|   int64_t endMs = taosGetTimestampMs();
 | |
|   int64_t totalTables = t - pInfo->tableBeginIndex;
 | |
|   float   seconds = (endMs - pInfo->startMs) / 1000.0;
 | |
|   float   speed = totalTables / seconds;
 | |
|   pInfo->createTableSpeed = speed;
 | |
|   pPrint("thread:%d, %" PRId64 " tables created, time:%.2f sec, speed:%.1f tables/second, ", pInfo->threadIndex,
 | |
|          totalTables, seconds, speed);
 | |
| }
 | |
| 
 | |
| void printInsertProgress(SThreadInfo *pInfo, int64_t insertTotalRows) {
 | |
|   int64_t endMs = taosGetTimestampMs();
 | |
|   //int64_t totalTables = t - pInfo->tableBeginIndex;
 | |
|   float   seconds = (endMs - pInfo->startMs) / 1000.0;
 | |
|   float   speed = insertTotalRows / seconds;
 | |
|   pInfo->insertDataSpeed = speed;
 | |
|   pPrint("thread:%d, %" PRId64 " rows inserted, time:%.2f sec, speed:%.1f rows/second, ", pInfo->threadIndex,
 | |
|          insertTotalRows, seconds, speed);
 | |
| }
 | |
| 
 | |
| static int64_t getResult(TAOS_RES *tres) {
 | |
|   TAOS_ROW row = taos_fetch_row(tres);
 | |
|   if (row == NULL) {
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   int         num_fields = taos_num_fields(tres);
 | |
|   TAOS_FIELD *fields = taos_fetch_fields(tres);
 | |
|   int         precision = taos_result_precision(tres);
 | |
| 
 | |
|   int64_t numOfRows = 0;
 | |
|   do {
 | |
|     numOfRows++;
 | |
|     row = taos_fetch_row(tres);
 | |
|   } while (row != NULL);
 | |
| 
 | |
|   return numOfRows;
 | |
| }
 | |
| 
 | |
| void showTables() {
 | |
|   pPrint("start to show tables");
 | |
|   char qstr[128];
 | |
| 
 | |
|   TAOS *con = taos_connect(NULL, "root", "taosdata", NULL, 0);
 | |
|   if (con == NULL) {
 | |
|     pError("failed to connect to DB, reason:%s", taos_errstr(NULL));
 | |
|     exit(1);
 | |
|   }
 | |
| 
 | |
|   snprintf(qstr, 128, "use %s", dbName);
 | |
|   TAOS_RES *pRes = taos_query(con, qstr);
 | |
|   int       code = taos_errno(pRes);
 | |
|   if (code != 0) {
 | |
|     pError("failed to use db, code:%d reason:%s", taos_errno(pRes), taos_errstr(pRes));
 | |
|     exit(1);
 | |
|   }
 | |
|   taos_free_result(pRes);
 | |
| 
 | |
|   sprintf(qstr, "show tables");
 | |
|   pRes = taos_query(con, qstr);
 | |
|   code = taos_errno(pRes);
 | |
|   if (code != 0) {
 | |
|     pError("failed to show tables, code:%d reason:%s", taos_errno(pRes), taos_errstr(pRes));
 | |
|     exit(0);
 | |
|   }
 | |
| 
 | |
|   int64_t totalTableNum = getResult(pRes);
 | |
|   taos_free_result(pRes);
 | |
| 
 | |
|   pPrint("%s database: %s, total %" PRId64 " tables %s", GREEN, dbName, totalTableNum, NC);
 | |
| 
 | |
|   taos_close(con);
 | |
| }
 | |
| 
 | |
| void *threadFunc(void *param) {
 | |
|   SThreadInfo *pInfo = (SThreadInfo *)param;
 | |
|   char        *qstr = taosMemoryMalloc(batchNumOfTbl * batchNumOfRow * 128);
 | |
|   int32_t      code = 0;
 | |
| 
 | |
|   TAOS *con = taos_connect(NULL, "root", "taosdata", NULL, 0);
 | |
|   if (con == NULL) {
 | |
|     pError("index:%d, failed to connect to DB, reason:%s", pInfo->threadIndex, taos_errstr(NULL));
 | |
|     exit(1);
 | |
|   }
 | |
| 
 | |
|   //pPrint("====before thread:%d, table range: %" PRId64 " - %" PRId64 "\n", pInfo->threadIndex, pInfo->tableBeginIndex,
 | |
|   //       pInfo->tableEndIndex);
 | |
| 
 | |
|   pInfo->tableBeginIndex += startOffset;
 | |
|   pInfo->tableEndIndex += startOffset;
 | |
| 
 | |
|   pPrint("====thread:%d, table range: %" PRId64 " - %" PRId64 "\n", pInfo->threadIndex, pInfo->tableBeginIndex, pInfo->tableEndIndex);
 | |
| 
 | |
|   sprintf(qstr, "use %s", pInfo->dbName);
 | |
|   TAOS_RES *pRes = taos_query(con, qstr);
 | |
|   taos_free_result(pRes);
 | |
| 
 | |
|   if (createTable) {
 | |
|     int64_t curMs = 0;
 | |
|     int64_t beginMs = taosGetTimestampMs();
 | |
|     pInfo->startMs = beginMs;
 | |
|     int64_t t = pInfo->tableBeginIndex;
 | |
|     for (; t <= pInfo->tableEndIndex;) {
 | |
|       // int64_t batch = (pInfo->tableEndIndex - t);
 | |
|       // batch = TMIN(batch, batchNum);
 | |
| 
 | |
|       int32_t len = sprintf(qstr, "create table");
 | |
|       for (int32_t i = 0; i < batchNumOfTbl;) {
 | |
|         len += sprintf(qstr + len, " %s_t%" PRId64 " using %s tags(%" PRId64 ")", stbName, t, stbName, t);
 | |
|         t++;
 | |
|         i++;
 | |
|         if (t > pInfo->tableEndIndex) {
 | |
|           break;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       int64_t   startTs = taosGetTimestampUs();
 | |
|       TAOS_RES *pRes = taos_query(con, qstr);
 | |
|       code = taos_errno(pRes);
 | |
|       if (code != 0) {
 | |
|         pError("failed to create table reason:%s, sql: %s", tstrerror(code), qstr);
 | |
|       }
 | |
|       taos_free_result(pRes);
 | |
|       int64_t endTs = taosGetTimestampUs();
 | |
|       int64_t delay = endTs - startTs;
 | |
|       // printf("==== %"PRId64" -  %"PRId64", %"PRId64"\n", startTs, endTs, delay);
 | |
|       if (delay > pInfo->maxDelay) pInfo->maxDelay = delay;
 | |
|       if (delay < pInfo->minDelay) pInfo->minDelay = delay;
 | |
| 
 | |
|       curMs = taosGetTimestampMs();
 | |
|       if (curMs - beginMs > 10000) {
 | |
|         beginMs = curMs;
 | |
|         // printf("==== tableBeginIndex: %"PRId64", t: %"PRId64"\n", pInfo->tableBeginIndex, t);
 | |
|         printCreateProgress(pInfo, t);
 | |
|       }
 | |
|     }
 | |
|     printCreateProgress(pInfo, t);
 | |
|   }
 | |
| 
 | |
|   if (insertData) {
 | |
|   	int64_t insertTotalRows = 0;
 | |
|     int64_t curMs = 0;
 | |
|     int64_t beginMs = taosGetTimestampMs();
 | |
|     pInfo->startMs = beginMs;
 | |
|     int64_t t = pInfo->tableBeginIndex;
 | |
|     for (; t <= pInfo->tableEndIndex; t++) {
 | |
|       //printf("table name: %"PRId64"\n", t);
 | |
|       int64_t ts = startTimestamp;
 | |
|       for (int32_t i = 0; i < totalRowsOfPerTbl;) {
 | |
|         int32_t len = sprintf(qstr, "insert into ");
 | |
|         len += sprintf(qstr + len, "%s_t%" PRId64 " values ", stbName, t);
 | |
|         for (int32_t j = 0; j < batchNumOfRow; j++) {
 | |
|           len += sprintf(qstr + len, "(%" PRId64 ", 6666) ", ts++);
 | |
| 		  i++;
 | |
| 		  insertTotalRows++;
 | |
| 		  if (i >= totalRowsOfPerTbl) {
 | |
| 		  	break;
 | |
| 		  }
 | |
|         }
 | |
| 
 | |
|         #if 1
 | |
|         int64_t	startTs = taosGetTimestampUs();
 | |
|         TAOS_RES *pRes = taos_query(con, qstr);
 | |
|         code = taos_errno(pRes);
 | |
|         if (code != 0) {
 | |
|           pError("failed to insert %s_t%" PRId64 ", reason:%s", stbName, t, tstrerror(code));
 | |
|         }
 | |
|         taos_free_result(pRes);
 | |
|         int64_t endTs = taosGetTimestampUs();
 | |
|         int64_t delay = endTs - startTs;
 | |
|         // printf("==== %"PRId64" -  %"PRId64", %"PRId64"\n", startTs, endTs, delay);
 | |
|         if (delay > pInfo->maxDelay) pInfo->maxDelay = delay;
 | |
|         if (delay < pInfo->minDelay) pInfo->minDelay = delay;
 | |
|         
 | |
|         curMs = taosGetTimestampMs();
 | |
|         if (curMs - beginMs > 10000) {
 | |
|           beginMs = curMs;
 | |
|           // printf("==== tableBeginIndex: %"PRId64", t: %"PRId64"\n", pInfo->tableBeginIndex, t);
 | |
|           printInsertProgress(pInfo, insertTotalRows);
 | |
|         }
 | |
|         #endif		
 | |
|       }
 | |
|     }	
 | |
|     printInsertProgress(pInfo, insertTotalRows);    
 | |
|   }
 | |
| 
 | |
|   taos_close(con);
 | |
|   taosMemoryFree(qstr);
 | |
|   return 0;
 | |
| }
 | |
| 
 | |
| void printHelp() {
 | |
|   char indent[10] = "        ";
 | |
|   printf("Used to test the performance while create table\n");
 | |
| 
 | |
|   printf("%s%s\n", indent, "-c");
 | |
|   printf("%s%s%s%s\n", indent, indent, "Configuration directory, default is ", configDir);
 | |
|   printf("%s%s\n", indent, "-d");
 | |
|   printf("%s%s%s%s\n", indent, indent, "The name of the database to be created, default is ", dbName);
 | |
|   printf("%s%s\n", indent, "-s");
 | |
|   printf("%s%s%s%s\n", indent, indent, "The name of the super table to be created, default is ", stbName);
 | |
|   printf("%s%s\n", indent, "-t");
 | |
|   printf("%s%s%s%d\n", indent, indent, "numOfThreads, default is ", numOfThreads);
 | |
|   printf("%s%s\n", indent, "-n");
 | |
|   printf("%s%s%s%" PRId64 "\n", indent, indent, "numOfTables, default is ", numOfTables);
 | |
|   printf("%s%s\n", indent, "-g");
 | |
|   printf("%s%s%s%" PRId64 "\n", indent, indent, "startOffset, default is ", startOffset);
 | |
|   printf("%s%s\n", indent, "-v");
 | |
|   printf("%s%s%s%d\n", indent, indent, "numOfVgroups, default is ", numOfVgroups);
 | |
|   printf("%s%s\n", indent, "-a");
 | |
|   printf("%s%s%s%d\n", indent, indent, "createTable, default is ", createTable);
 | |
|   printf("%s%s\n", indent, "-i");
 | |
|   printf("%s%s%s%d\n", indent, indent, "insertData, default is ", insertData);
 | |
|   printf("%s%s\n", indent, "-b");
 | |
|   printf("%s%s%s%d\n", indent, indent, "batchNumOfTbl, default is ", batchNumOfTbl);
 | |
|   printf("%s%s\n", indent, "-w");
 | |
|   printf("%s%s%s%d\n", indent, indent, "showTablesFlag, default is ", showTablesFlag);
 | |
|   printf("%s%s\n", indent, "-q");
 | |
|   printf("%s%s%s%d\n", indent, indent, "queryFlag, default is ", queryFlag);
 | |
|   printf("%s%s\n", indent, "-l");
 | |
|   printf("%s%s%s%d\n", indent, indent, "batchNumOfRow, default is ", batchNumOfRow);
 | |
|   printf("%s%s\n", indent, "-r");
 | |
|   printf("%s%s%s%d\n", indent, indent, "totalRowsOfPerTbl, default is ", totalRowsOfPerTbl);
 | |
| 
 | |
|   exit(EXIT_SUCCESS);
 | |
| }
 | |
| 
 | |
| void parseArgument(int32_t argc, char *argv[]) {
 | |
|   for (int32_t i = 1; i < argc; i++) {
 | |
|     if (strcmp(argv[i], "-h") == 0 || strcmp(argv[i], "--help") == 0) {
 | |
|       printHelp();
 | |
|       exit(0);
 | |
|     } else if (strcmp(argv[i], "-d") == 0) {
 | |
|       tstrncpy(dbName, argv[++i], sizeof(dbName));
 | |
|     } else if (strcmp(argv[i], "-c") == 0) {
 | |
|       tstrncpy(configDir, argv[++i], PATH_MAX);
 | |
|     } else if (strcmp(argv[i], "-s") == 0) {
 | |
|       tstrncpy(stbName, argv[++i], sizeof(stbName));
 | |
|     } else if (strcmp(argv[i], "-t") == 0) {
 | |
|       numOfThreads = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-n") == 0) {
 | |
|       numOfTables = atoll(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-g") == 0) {
 | |
|       startOffset = atoll(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-v") == 0) {
 | |
|       numOfVgroups = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-a") == 0) {
 | |
|       createTable = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-i") == 0) {
 | |
|       insertData = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-b") == 0) {
 | |
|       batchNumOfTbl = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-l") == 0) {
 | |
|       batchNumOfRow = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-r") == 0) {
 | |
|       totalRowsOfPerTbl = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-w") == 0) {
 | |
|       showTablesFlag = atoi(argv[++i]);
 | |
|     } else if (strcmp(argv[i], "-q") == 0) {
 | |
|       queryFlag = atoi(argv[++i]);
 | |
|     } else {
 | |
|       pPrint("%s unknow para: %s %s", GREEN, argv[++i], NC);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   pPrint("%s dbName:%s %s", GREEN, dbName, NC);
 | |
|   pPrint("%s stbName:%s %s", GREEN, stbName, NC);
 | |
|   pPrint("%s configDir:%s %s", GREEN, configDir, NC);
 | |
|   pPrint("%s numOfTables:%" PRId64 " %s", GREEN, numOfTables, NC);
 | |
|   pPrint("%s startOffset:%" PRId64 " %s", GREEN, startOffset, NC);
 | |
|   pPrint("%s numOfThreads:%d %s", GREEN, numOfThreads, NC);
 | |
|   pPrint("%s numOfVgroups:%d %s", GREEN, numOfVgroups, NC);
 | |
|   pPrint("%s createTable:%d %s", GREEN, createTable, NC);
 | |
|   pPrint("%s insertData:%d %s", GREEN, insertData, NC);
 | |
|   pPrint("%s batchNumOfTbl:%d %s", GREEN, batchNumOfTbl, NC);
 | |
|   pPrint("%s batchNumOfRow:%d %s", GREEN, batchNumOfRow, NC);
 | |
|   pPrint("%s totalRowsOfPerTbl:%d %s", GREEN, totalRowsOfPerTbl, NC);
 | |
|   pPrint("%s showTablesFlag:%d %s", GREEN, showTablesFlag, NC);
 | |
|   pPrint("%s queryFlag:%d %s", GREEN, queryFlag, NC);
 | |
| 
 | |
|   pPrint("%s start create table performace test %s", GREEN, NC);
 | |
| }
 | |
| 
 | |
| int32_t main(int32_t argc, char *argv[]) {
 | |
|   parseArgument(argc, argv);
 | |
| 
 | |
|   if (showTablesFlag) {
 | |
|     showTables();
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   if (queryFlag) {
 | |
|     // selectRowsFromTable();
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   if (createTable) {
 | |
|     createDbAndStb();
 | |
|   }
 | |
| 
 | |
|   pPrint("%d threads are spawned to create %" PRId64 " tables, offset is %" PRId64 " ", numOfThreads, numOfTables,
 | |
|          startOffset);
 | |
| 
 | |
|   TdThreadAttr thattr;
 | |
|   taosThreadAttrInit(&thattr);
 | |
|   taosThreadAttrSetDetachState(&thattr, PTHREAD_CREATE_JOINABLE);
 | |
|   SThreadInfo *pInfo = (SThreadInfo *)taosMemoryCalloc(numOfThreads, sizeof(SThreadInfo));
 | |
| 
 | |
|   // int64_t numOfTablesPerThread = numOfTables / numOfThreads;
 | |
|   // numOfTables = numOfTablesPerThread * numOfThreads;
 | |
| 
 | |
|   if (numOfThreads < 1) {
 | |
|     numOfThreads = 1;
 | |
|   }
 | |
| 
 | |
|   int64_t a = numOfTables / numOfThreads;
 | |
|   if (a < 1) {
 | |
|     numOfThreads = numOfTables;
 | |
|     a = 1;
 | |
|   }
 | |
| 
 | |
|   int64_t b = 0;
 | |
|   b = numOfTables % numOfThreads;
 | |
| 
 | |
|   int64_t tableFrom = 0;
 | |
|   for (int32_t i = 0; i < numOfThreads; ++i) {
 | |
|     pInfo[i].tableBeginIndex = tableFrom;
 | |
|     pInfo[i].tableEndIndex = (i < b ? tableFrom + a : tableFrom + a - 1);
 | |
|     tableFrom = pInfo[i].tableEndIndex + 1;
 | |
|     pInfo[i].threadIndex = i;
 | |
|     pInfo[i].minDelay = INT64_MAX;
 | |
|     strcpy(pInfo[i].dbName, dbName);
 | |
|     strcpy(pInfo[i].stbName, stbName);
 | |
|     taosThreadCreate(&(pInfo[i].thread), &thattr, threadFunc, (void *)(pInfo + i));
 | |
|   }
 | |
| 
 | |
|   taosMsleep(300);
 | |
|   for (int32_t i = 0; i < numOfThreads; i++) {
 | |
|     taosThreadJoin(pInfo[i].thread, NULL);
 | |
|     taosThreadClear(&pInfo[i].thread);
 | |
|   }
 | |
| 
 | |
|   int64_t maxDelay = 0;
 | |
|   int64_t minDelay = INT64_MAX;
 | |
| 
 | |
|   float createTableSpeed = 0;
 | |
|   for (int32_t i = 0; i < numOfThreads; ++i) {
 | |
|     createTableSpeed += pInfo[i].createTableSpeed;
 | |
| 
 | |
|     if (pInfo[i].maxDelay > maxDelay) maxDelay = pInfo[i].maxDelay;
 | |
|     if (pInfo[i].minDelay < minDelay) minDelay = pInfo[i].minDelay;
 | |
|   }
 | |
| 
 | |
|   float insertDataSpeed = 0;
 | |
|   for (int32_t i = 0; i < numOfThreads; ++i) {
 | |
|     insertDataSpeed += pInfo[i].insertDataSpeed;
 | |
|   }
 | |
| 
 | |
|   if (createTable) {
 | |
|     pPrint("%s total %" PRId64 " tables, %.1f tables/second, threads:%d, maxDelay: %" PRId64 "us, minDelay: %" PRId64
 | |
|            "us %s",
 | |
|            GREEN, numOfTables, createTableSpeed, numOfThreads, maxDelay, minDelay, NC);
 | |
|   }
 | |
| 
 | |
|   if (insertData) {
 | |
|     pPrint("%s total %" PRId64 " tables, %.1f rows/second, threads:%d %s", GREEN, numOfTables, insertDataSpeed,
 | |
|            numOfThreads, NC);
 | |
|   }
 | |
| 
 | |
|   taosThreadAttrDestroy(&thattr);
 | |
|   taosMemoryFree(pInfo);
 | |
| }
 |