Feature/sangshuduo/td 5053 taosdump support nanosecond (#6769)
* [TD-5053]<feature>: taosdump support nanosecond huge code refactoring * fix arm32 compile issue. * [TD-5053]<feature>: taosdump supports nanosecond. * fix precision parsing order issue.
This commit is contained in:
parent
7c869c765a
commit
8ab4b3131a
|
@ -226,15 +226,16 @@ static struct argp_option options[] = {
|
|||
{"schemaonly", 's', 0, 0, "Only dump schema.", 2},
|
||||
{"without-property", 'N', 0, 0, "Dump schema without properties.", 2},
|
||||
{"avro", 'V', 0, 0, "Dump apache avro format data file. By default, dump sql command sequence.", 2},
|
||||
{"start-time", 'S', "START_TIME", 0, "Start time to dump. Either Epoch or ISO8601/RFC3339 format is acceptable. Epoch precision millisecond. ISO8601 format example: 2017-10-01T18:00:00.000+0800 or 2017-10-0100:00:00.000+0800 or '2017-10-01 00:00:00.000+0800'", 3},
|
||||
{"end-time", 'E', "END_TIME", 0, "End time to dump. Either Epoch or ISO8601/RFC3339 format is acceptable. Epoch precision millisecond. ISO8601 format example: 2017-10-01T18:00:00.000+0800 or 2017-10-0100:00:00.000+0800 or '2017-10-01 00:00:00.000+0800'", 3},
|
||||
{"start-time", 'S', "START_TIME", 0, "Start time to dump. Either epoch or ISO8601/RFC3339 format is acceptable. ISO8601 format example: 2017-10-01T18:00:00.000+0800 or 2017-10-0100:00:00.000+0800 or '2017-10-01 00:00:00.000+0800'", 4},
|
||||
{"end-time", 'E', "END_TIME", 0, "End time to dump. Either epoch or ISO8601/RFC3339 format is acceptable. ISO8601 format example: 2017-10-01T18:00:00.000+0800 or 2017-10-0100:00:00.000+0800 or '2017-10-01 00:00:00.000+0800'", 5},
|
||||
{"precision", 'C', "PRECISION", 0, "Epoch precision. Valid value is one of ms, us, and ns. Default is ms.", 6},
|
||||
{"data-batch", 'B', "DATA_BATCH", 0, "Number of data point per insert statement. Max value is 32766. Default is 1.", 3},
|
||||
{"max-sql-len", 'L', "SQL_LEN", 0, "Max length of one sql. Default is 65480.", 3},
|
||||
{"table-batch", 't', "TABLE_BATCH", 0, "Number of table dumpout into one output file. Default is 1.", 3},
|
||||
{"thread_num", 'T', "THREAD_NUM", 0, "Number of thread for dump in file. Default is 5.", 3},
|
||||
{"debug", 'g', 0, 0, "Print debug info.", 4},
|
||||
{"verbose", 'b', 0, 0, "Print verbose debug info.", 5},
|
||||
{"performanceprint", 'm', 0, 0, "Print performance debug info.", 5},
|
||||
{"debug", 'g', 0, 0, "Print debug info.", 8},
|
||||
{"verbose", 'b', 0, 0, "Print verbose debug info.", 9},
|
||||
{"performanceprint", 'm', 0, 0, "Print performance debug info.", 10},
|
||||
{0}
|
||||
};
|
||||
|
||||
|
@ -262,6 +263,7 @@ typedef struct arguments {
|
|||
bool avro;
|
||||
int64_t start_time;
|
||||
int64_t end_time;
|
||||
char precision[8];
|
||||
int32_t data_batch;
|
||||
int32_t max_sql_len;
|
||||
int32_t table_batch; // num of table which will be dump into one output file.
|
||||
|
@ -329,8 +331,9 @@ struct arguments g_args = {
|
|||
false, // schemeonly
|
||||
true, // with_property
|
||||
false, // avro format
|
||||
0, // start_time
|
||||
-INT64_MAX, // start_time
|
||||
INT64_MAX, // end_time
|
||||
"ms", // precision
|
||||
1, // data_batch
|
||||
TSDB_MAX_SQL_LEN, // max_sql_len
|
||||
1, // table_batch
|
||||
|
@ -508,41 +511,84 @@ static int queryDbImpl(TAOS *taos, char *command) {
|
|||
return 0;
|
||||
}
|
||||
|
||||
static void parse_args(int argc, char *argv[], SArguments *arguments) {
|
||||
static void parse_precision_first(
|
||||
int argc, char *argv[], SArguments *arguments) {
|
||||
for (int i = 1; i < argc; i++) {
|
||||
if ((strcmp(argv[i], "-S") == 0)
|
||||
|| (strcmp(argv[i], "-E") == 0)) {
|
||||
if (argv[i+1]) {
|
||||
char *tmp = strdup(argv[++i]);
|
||||
|
||||
if (tmp) {
|
||||
int64_t tmpEpoch;
|
||||
if (strchr(tmp, ':') && strchr(tmp, '-')) {
|
||||
if (TSDB_CODE_SUCCESS != taosParseTime(
|
||||
tmp, &tmpEpoch, strlen(tmp), TSDB_TIME_PRECISION_MILLI, 0)) {
|
||||
errorPrint("Input %s, end time error!\n", tmp);
|
||||
free(tmp);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
tmpEpoch = atoll(tmp);
|
||||
}
|
||||
|
||||
sprintf(argv[i], "%"PRId64"", tmpEpoch);
|
||||
debugPrint("%s() LN%d, tmp is: %s, argv[%d]: %s\n",
|
||||
__func__, __LINE__, tmp, i, argv[i]);
|
||||
|
||||
free(tmp);
|
||||
} else {
|
||||
errorPrint("%s() LN%d, strdup() cannot allocate memory\n", __func__, __LINE__);
|
||||
exit(-1);
|
||||
}
|
||||
} else {
|
||||
if (strcmp(argv[i], "-C") == 0) {
|
||||
if (NULL == argv[i+1]) {
|
||||
errorPrint("%s need a valid value following!\n", argv[i]);
|
||||
exit(-1);
|
||||
}
|
||||
} else if (strcmp(argv[i], "-g") == 0) {
|
||||
g_args.debug_print = true;
|
||||
char *tmp = strdup(argv[i+1]);
|
||||
if (tmp == NULL) {
|
||||
errorPrint("%s() LN%d, strdup() cannot allocate memory\n",
|
||||
__func__, __LINE__);
|
||||
exit(-1);
|
||||
}
|
||||
if ((0 != strncasecmp(tmp, "ms", strlen("ms")))
|
||||
&& (0 != strncasecmp(tmp, "us", strlen("us")))
|
||||
&& (0 != strncasecmp(tmp, "ns", strlen("ns")))) {
|
||||
//
|
||||
errorPrint("input precision: %s is invalid value\n", tmp);
|
||||
free(tmp);
|
||||
exit(-1);
|
||||
}
|
||||
strncpy(g_args.precision, tmp, strlen(tmp));
|
||||
free(tmp);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void parse_timestamp(
|
||||
int argc, char *argv[], SArguments *arguments) {
|
||||
for (int i = 1; i < argc; i++) {
|
||||
if ((strcmp(argv[i], "-S") == 0)
|
||||
|| (strcmp(argv[i], "-E") == 0)) {
|
||||
if (NULL == argv[i+1]) {
|
||||
errorPrint("%s need a valid value following!\n", argv[i]);
|
||||
exit(-1);
|
||||
}
|
||||
char *tmp = strdup(argv[i+1]);
|
||||
if (NULL == tmp) {
|
||||
errorPrint("%s() LN%d, strdup() cannot allocate memory\n",
|
||||
__func__, __LINE__);
|
||||
exit(-1);
|
||||
}
|
||||
|
||||
int64_t tmpEpoch;
|
||||
if (strchr(tmp, ':') && strchr(tmp, '-')) {
|
||||
int32_t timePrec;
|
||||
if (0 == strncasecmp(arguments->precision,
|
||||
"ms", strlen("ms"))) {
|
||||
timePrec = TSDB_TIME_PRECISION_MILLI;
|
||||
} else if (0 == strncasecmp(arguments->precision,
|
||||
"us", strlen("us"))) {
|
||||
timePrec = TSDB_TIME_PRECISION_MICRO;
|
||||
} else if (0 == strncasecmp(arguments->precision,
|
||||
"ns", strlen("ns"))) {
|
||||
timePrec = TSDB_TIME_PRECISION_NANO;
|
||||
} else {
|
||||
errorPrint("Invalid time precision: %s",
|
||||
arguments->precision);
|
||||
free(tmp);
|
||||
return;
|
||||
}
|
||||
|
||||
if (TSDB_CODE_SUCCESS != taosParseTime(
|
||||
tmp, &tmpEpoch, strlen(tmp),
|
||||
timePrec, 0)) {
|
||||
errorPrint("Input %s, end time error!\n", tmp);
|
||||
free(tmp);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
tmpEpoch = atoll(tmp);
|
||||
}
|
||||
|
||||
sprintf(argv[i], "%"PRId64"", tmpEpoch);
|
||||
debugPrint("%s() LN%d, tmp is: %s, argv[%d]: %s\n",
|
||||
__func__, __LINE__, tmp, i, argv[i]);
|
||||
free(tmp);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -552,8 +598,10 @@ int main(int argc, char *argv[]) {
|
|||
int ret = 0;
|
||||
/* Parse our arguments; every option seen by parse_opt will be
|
||||
reflected in arguments. */
|
||||
if (argc > 2)
|
||||
parse_args(argc, argv, &g_args);
|
||||
if (argc > 2) {
|
||||
parse_precision_first(argc, argv, &g_args);
|
||||
parse_timestamp(argc, argv, &g_args);
|
||||
}
|
||||
|
||||
argp_parse(&argp, argc, argv, 0, 0, &g_args);
|
||||
|
||||
|
@ -584,6 +632,7 @@ int main(int argc, char *argv[]) {
|
|||
printf("avro format: %s\n", g_args.avro?"true":"false");
|
||||
printf("start_time: %" PRId64 "\n", g_args.start_time);
|
||||
printf("end_time: %" PRId64 "\n", g_args.end_time);
|
||||
printf("precision: %s\n", g_args.precision);
|
||||
printf("data_batch: %d\n", g_args.data_batch);
|
||||
printf("max_sql_len: %d\n", g_args.max_sql_len);
|
||||
printf("table_batch: %d\n", g_args.table_batch);
|
||||
|
@ -634,6 +683,7 @@ int main(int argc, char *argv[]) {
|
|||
fprintf(g_fpOfResult, "avro format: %s\n", g_args.avro?"true":"false");
|
||||
fprintf(g_fpOfResult, "start_time: %" PRId64 "\n", g_args.start_time);
|
||||
fprintf(g_fpOfResult, "end_time: %" PRId64 "\n", g_args.end_time);
|
||||
fprintf(g_fpOfResult, "precision: %s\n", g_args.precision);
|
||||
fprintf(g_fpOfResult, "data_batch: %d\n", g_args.data_batch);
|
||||
fprintf(g_fpOfResult, "max_sql_len: %d\n", g_args.max_sql_len);
|
||||
fprintf(g_fpOfResult, "table_batch: %d\n", g_args.table_batch);
|
||||
|
|
Loading…
Reference in New Issue