TD-1225
This commit is contained in:
parent
80eddb19df
commit
41a21ca29e
|
@ -526,7 +526,7 @@ int tsParseValues(char **str, STableDataBlocks *pDataBlock, STableMeta *pTableMe
|
||||||
int32_t index = 0;
|
int32_t index = 0;
|
||||||
SStrToken sToken;
|
SStrToken sToken;
|
||||||
|
|
||||||
int16_t numOfRows = 0;
|
int32_t numOfRows = 0;
|
||||||
|
|
||||||
SSchema *pSchema = tscGetTableSchema(pTableMeta);
|
SSchema *pSchema = tscGetTableSchema(pTableMeta);
|
||||||
STableComInfo tinfo = tscGetTableInfo(pTableMeta);
|
STableComInfo tinfo = tscGetTableInfo(pTableMeta);
|
||||||
|
|
|
@ -317,10 +317,10 @@ static bool httpReadData(HttpContext *pContext) {
|
||||||
pContext->lastAccessTime = taosGetTimestampSec();
|
pContext->lastAccessTime = taosGetTimestampSec();
|
||||||
|
|
||||||
char buf[HTTP_STEP_SIZE + 1] = {0};
|
char buf[HTTP_STEP_SIZE + 1] = {0};
|
||||||
int32_t nread = (int32_t)taosReadSocket(pContext->fd, buf, sizeof(buf));
|
int32_t nread = (int32_t)taosReadSocket(pContext->fd, buf, HTTP_STEP_SIZE);
|
||||||
if (nread > 0) {
|
if (nread > 0) {
|
||||||
buf[nread] = '\0';
|
buf[nread] = '\0';
|
||||||
httpTrace("context:%p, fd:%d, nread:%d", pContext, pContext->fd, nread);
|
httpTraceL("context:%p, fd:%d, nread:%d content:%s", pContext, pContext->fd, nread, buf);
|
||||||
int32_t ok = httpParseBuf(pParser, buf, nread);
|
int32_t ok = httpParseBuf(pParser, buf, nread);
|
||||||
|
|
||||||
if (ok) {
|
if (ok) {
|
||||||
|
@ -341,7 +341,7 @@ static bool httpReadData(HttpContext *pContext) {
|
||||||
httpTrace("context:%p, fd:%d, read not over yet, len:%d", pContext, pContext->fd, pParser->body.pos);
|
httpTrace("context:%p, fd:%d, read not over yet, len:%d", pContext, pContext->fd, pParser->body.pos);
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
httpTraceL("context:%p, fd:%d, len:%d, body:%s", pContext, pContext->fd, pParser->body.pos, pParser->body.str);
|
httpDebug("context:%p, fd:%d, totalLen:%d", pContext, pContext->fd, pParser->body.pos);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} else if (nread < 0) {
|
} else if (nread < 0) {
|
||||||
|
|
|
@ -24,5 +24,10 @@ print curl 127.0.0.1:7111/rest/sql -----> $system_content
|
||||||
# return -1
|
# return -1
|
||||||
#endi
|
#endi
|
||||||
|
|
||||||
|
sql select * from db.win_cpu_windows_1_processor
|
||||||
|
print rows: $rows
|
||||||
|
if $rows != 1 then
|
||||||
|
return -1
|
||||||
|
endi
|
||||||
|
|
||||||
#system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
#system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
|
@ -0,0 +1,37 @@
|
||||||
|
system sh/stop_dnodes.sh
|
||||||
|
sleep 3000
|
||||||
|
system sh/deploy.sh -n dnode1 -i 1
|
||||||
|
system sh/cfg.sh -n dnode1 -c wallevel -v 0
|
||||||
|
system sh/cfg.sh -n dnode1 -c http -v 1
|
||||||
|
system sh/cfg.sh -n dnode1 -c maxSQLLength -v 7340032
|
||||||
|
system sh/exec.sh -n dnode1 -s start
|
||||||
|
|
||||||
|
sleep 3000
|
||||||
|
sql connect
|
||||||
|
|
||||||
|
print ============================ dnode1 start
|
||||||
|
|
||||||
|
print =============== step1 - prepare data
|
||||||
|
sql create database d1
|
||||||
|
sql use d1
|
||||||
|
|
||||||
|
sql create table table_rest (ts timestamp, i int)
|
||||||
|
print sql length is 270KB
|
||||||
|
restful d1 table_rest 1591072800 10000
|
||||||
|
restful d1 table_rest 1591172800 10000
|
||||||
|
restful d1 table_rest 1591272800 10000
|
||||||
|
restful d1 table_rest 1591372800 10000
|
||||||
|
restful d1 table_rest 1591472800 10000
|
||||||
|
restful d1 table_rest 1591572800 10000
|
||||||
|
restful d1 table_rest 1591672800 10000
|
||||||
|
restful d1 table_rest 1591772800 10000
|
||||||
|
restful d1 table_rest 1591872800 10000
|
||||||
|
restful d1 table_rest 1591972800 10000
|
||||||
|
|
||||||
|
sql select * from table_rest;
|
||||||
|
print rows: $rows
|
||||||
|
if $rows != 100000 then
|
||||||
|
return -1
|
||||||
|
endi
|
||||||
|
|
||||||
|
system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
|
@ -0,0 +1,27 @@
|
||||||
|
system sh/stop_dnodes.sh
|
||||||
|
sleep 3000
|
||||||
|
system sh/deploy.sh -n dnode1 -i 1
|
||||||
|
system sh/cfg.sh -n dnode1 -c wallevel -v 0
|
||||||
|
system sh/cfg.sh -n dnode1 -c http -v 1
|
||||||
|
system sh/cfg.sh -n dnode1 -c maxSQLLength -v 7340032
|
||||||
|
system sh/exec.sh -n dnode1 -s start
|
||||||
|
|
||||||
|
sleep 3000
|
||||||
|
sql connect
|
||||||
|
|
||||||
|
print ============================ dnode1 start
|
||||||
|
|
||||||
|
print =============== step1 - prepare data
|
||||||
|
sql create database d1
|
||||||
|
sql use d1
|
||||||
|
|
||||||
|
sql create table table_rest (ts timestamp, i int)
|
||||||
|
print sql length is 270KB
|
||||||
|
restful d1 table_rest 1591072800 10000 gzip
|
||||||
|
sql select * from table_rest;
|
||||||
|
print rows: $rows
|
||||||
|
if $rows != 10000 then
|
||||||
|
return -1
|
||||||
|
endi
|
||||||
|
|
||||||
|
system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
|
@ -1,3 +1,5 @@
|
||||||
|
run general/http/autocreate.sim
|
||||||
|
run general/http/chunked.sim
|
||||||
run general/http/restful.sim
|
run general/http/restful.sim
|
||||||
run general/http/restful_insert.sim
|
run general/http/restful_insert.sim
|
||||||
run general/http/restful_limit.sim
|
run general/http/restful_limit.sim
|
||||||
|
|
|
@ -77,6 +77,8 @@ cd ../../../debug; make
|
||||||
./test.sh -f general/field/smallint.sim
|
./test.sh -f general/field/smallint.sim
|
||||||
./test.sh -f general/field/tinyint.sim
|
./test.sh -f general/field/tinyint.sim
|
||||||
|
|
||||||
|
./test.sh -f general/http/autocreate.sim
|
||||||
|
./test.sh -f general/http/chunked.sim
|
||||||
./test.sh -f general/http/restful.sim
|
./test.sh -f general/http/restful.sim
|
||||||
./test.sh -f general/http/restful_insert.sim
|
./test.sh -f general/http/restful_insert.sim
|
||||||
./test.sh -f general/http/restful_limit.sim
|
./test.sh -f general/http/restful_limit.sim
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define _DEFAULT_SOURCE
|
#define _DEFAULT_SOURCE
|
||||||
|
#include <malloc.h>
|
||||||
#include "os.h"
|
#include "os.h"
|
||||||
#include "taos.h"
|
#include "taos.h"
|
||||||
#include "tcache.h"
|
#include "tcache.h"
|
||||||
|
@ -91,15 +92,17 @@ void doTest() {
|
||||||
putRowInCache();
|
putRowInCache();
|
||||||
pPrint("%s insert %d rows, procMemory %f MB %s", GREEN, tsNumOfRows, getProcMemory(), NC);
|
pPrint("%s insert %d rows, procMemory %f MB %s", GREEN, tsNumOfRows, getProcMemory(), NC);
|
||||||
|
|
||||||
int32_t sleepMs = (MAX_REFRESH_TIME_SEC * 3 + 10) * 1000 + tsKeepTimeInSec * 1000;
|
int32_t sleepMs = (MAX_REFRESH_TIME_SEC * 3) * 1000 + tsKeepTimeInSec * 1000;
|
||||||
taosMsleep(sleepMs);
|
taosMsleep(sleepMs);
|
||||||
pPrint("%s after sleep %d ms, procMemory %f MB %s", GREEN, sleepMs, getProcMemory(), NC);
|
pPrint("%s after sleep %d ms, procMemory %f MB %s", GREEN, sleepMs, getProcMemory(), NC);
|
||||||
|
|
||||||
//cleanupCache();
|
cleanupCache();
|
||||||
taosMsleep(sleepMs);
|
taosMsleep(sleepMs);
|
||||||
pPrint("%s after cleanup cache, procMemory %f MB %s", GREEN, getProcMemory(), NC);
|
pPrint("%s after cleanup cache, procMemory %f MB %s", GREEN, getProcMemory(), NC);
|
||||||
|
|
||||||
pPrint("%s finally destroyTimes:%d %s", GREEN, destroyTimes, NC);
|
malloc_trim(0);
|
||||||
|
taosMsleep(sleepMs);
|
||||||
|
pPrint("%s after malloc_trim, procMemory %f MB %s", GREEN, getProcMemory(), NC);
|
||||||
}
|
}
|
||||||
|
|
||||||
void printHelp() {
|
void printHelp() {
|
||||||
|
|
|
@ -84,6 +84,7 @@ enum {
|
||||||
SIM_CMD_SQL,
|
SIM_CMD_SQL,
|
||||||
SIM_CMD_SQL_ERROR,
|
SIM_CMD_SQL_ERROR,
|
||||||
SIM_CMD_SQL_SLOW,
|
SIM_CMD_SQL_SLOW,
|
||||||
|
SIM_CMD_RESTFUL,
|
||||||
SIM_CMD_TEST,
|
SIM_CMD_TEST,
|
||||||
SIM_CMD_RETURN,
|
SIM_CMD_RETURN,
|
||||||
SIM_CMD_END
|
SIM_CMD_END
|
||||||
|
@ -172,6 +173,7 @@ bool simExecuteReturnCmd(SScript *script, char *option);
|
||||||
bool simExecuteSqlCmd(SScript *script, char *option);
|
bool simExecuteSqlCmd(SScript *script, char *option);
|
||||||
bool simExecuteSqlErrorCmd(SScript *script, char *rest);
|
bool simExecuteSqlErrorCmd(SScript *script, char *rest);
|
||||||
bool simExecuteSqlSlowCmd(SScript *script, char *option);
|
bool simExecuteSqlSlowCmd(SScript *script, char *option);
|
||||||
|
bool simExecuteRestfulCmd(SScript *script, char *rest);
|
||||||
void simVisuallizeOption(SScript *script, char *src, char *dst);
|
void simVisuallizeOption(SScript *script, char *src, char *dst);
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -915,6 +915,47 @@ bool simExecuteSqlSlowCmd(SScript *script, char *rest) {
|
||||||
return simExecuteSqlImpCmd(script, rest, isSlow);
|
return simExecuteSqlImpCmd(script, rest, isSlow);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool simExecuteRestfulCmd(SScript *script, char *rest) {
|
||||||
|
FILE *fp = NULL;
|
||||||
|
char filename[256];
|
||||||
|
sprintf(filename, "%s/tmp.sql", tsScriptDir);
|
||||||
|
fp = fopen(filename, "w");
|
||||||
|
if (fp == NULL) {
|
||||||
|
fprintf(stderr, "ERROR: failed to open file: %s\n", filename);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
char db[64] = {0};
|
||||||
|
char tb[64] = {0};
|
||||||
|
char gzip[32] = {0};
|
||||||
|
int32_t ts;
|
||||||
|
int32_t times;
|
||||||
|
sscanf(rest, "%s %s %d %d %s", db, tb, &ts, ×, gzip);
|
||||||
|
|
||||||
|
fprintf(fp, "insert into %s.%s values ", db, tb);
|
||||||
|
for (int i = 0; i < times; ++i) {
|
||||||
|
fprintf(fp, "(%d000, %d)", ts + i, ts);
|
||||||
|
}
|
||||||
|
fprintf(fp, " \n");
|
||||||
|
fflush(fp);
|
||||||
|
fclose(fp);
|
||||||
|
|
||||||
|
char cmd[1024] = {0};
|
||||||
|
if (strcmp(gzip, "gzip") == 0) {
|
||||||
|
sprintf(cmd,
|
||||||
|
"curl -H 'Authorization: Taosd /KfeAzX/f9na8qdtNZmtONryp201ma04bEl8LcvLUd7a8qdtNZmtONryp201ma04' --header "
|
||||||
|
"--compressed --data-ascii @%s 127.0.0.1:7111/rest/sql",
|
||||||
|
filename);
|
||||||
|
} else {
|
||||||
|
sprintf(cmd,
|
||||||
|
"curl -H 'Authorization: Taosd /KfeAzX/f9na8qdtNZmtONryp201ma04bEl8LcvLUd7a8qdtNZmtONryp201ma04' --header "
|
||||||
|
"'Transfer-Encoding: chunked' --data-ascii @%s 127.0.0.1:7111/rest/sql",
|
||||||
|
filename);
|
||||||
|
}
|
||||||
|
|
||||||
|
return simExecuteSystemCmd(script, cmd);
|
||||||
|
}
|
||||||
|
|
||||||
bool simExecuteSqlErrorCmd(SScript *script, char *rest) {
|
bool simExecuteSqlErrorCmd(SScript *script, char *rest) {
|
||||||
char buf[3000];
|
char buf[3000];
|
||||||
SCmdLine *line = &script->lines[script->linePos];
|
SCmdLine *line = &script->lines[script->linePos];
|
||||||
|
|
|
@ -721,6 +721,12 @@ bool simParseSqlSlowCmd(char *rest, SCommand *pCmd, int lineNum) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool simParseRestfulCmd(char *rest, SCommand *pCmd, int lineNum) {
|
||||||
|
simParseSqlCmd(rest, pCmd, lineNum);
|
||||||
|
cmdLine[numOfLines - 1].cmdno = SIM_CMD_RESTFUL;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool simParseSystemCmd(char *rest, SCommand *pCmd, int lineNum) {
|
bool simParseSystemCmd(char *rest, SCommand *pCmd, int lineNum) {
|
||||||
int expLen;
|
int expLen;
|
||||||
|
|
||||||
|
@ -1020,6 +1026,14 @@ void simInitsimCmdList() {
|
||||||
simCmdList[cmdno].executeCmd = simExecuteSqlSlowCmd;
|
simCmdList[cmdno].executeCmd = simExecuteSqlSlowCmd;
|
||||||
simAddCmdIntoHash(&(simCmdList[cmdno]));
|
simAddCmdIntoHash(&(simCmdList[cmdno]));
|
||||||
|
|
||||||
|
cmdno = SIM_CMD_RESTFUL;
|
||||||
|
simCmdList[cmdno].cmdno = cmdno;
|
||||||
|
strcpy(simCmdList[cmdno].name, "restful");
|
||||||
|
simCmdList[cmdno].nlen = (int16_t)strlen(simCmdList[cmdno].name);
|
||||||
|
simCmdList[cmdno].parseCmd = simParseRestfulCmd;
|
||||||
|
simCmdList[cmdno].executeCmd = simExecuteRestfulCmd;
|
||||||
|
simAddCmdIntoHash(&(simCmdList[cmdno]));
|
||||||
|
|
||||||
/* test is only an internal command */
|
/* test is only an internal command */
|
||||||
cmdno = SIM_CMD_TEST;
|
cmdno = SIM_CMD_TEST;
|
||||||
simCmdList[cmdno].cmdno = cmdno;
|
simCmdList[cmdno].cmdno = cmdno;
|
||||||
|
|
Loading…
Reference in New Issue