Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
6ea659d1
T
TDengine
项目概览
慢慢CG
/
TDengine
与 Fork 源项目一致
Fork自
taosdata / TDengine
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
6ea659d1
编写于
6月 11, 2021
作者:
haoranc
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of github.com:taosdata/TDengine into test/chr
上级
6f6a02f8
63d68915
变更
32
展开全部
隐藏空白更改
内联
并排
Showing
32 changed file
with
2966 addition
and
2924 deletion
+2966
-2924
src/balance/src/bnMain.c
src/balance/src/bnMain.c
+4
-8
src/balance/src/bnThread.c
src/balance/src/bnThread.c
+4
-5
src/client/src/tscSub.c
src/client/src/tscSub.c
+8
-2
src/mnode/inc/mnodeDef.h
src/mnode/inc/mnodeDef.h
+1
-2
src/mnode/inc/mnodeDnode.h
src/mnode/inc/mnodeDnode.h
+1
-1
src/mnode/src/mnodeDnode.c
src/mnode/src/mnodeDnode.c
+6
-6
src/tsdb/src/tsdbRead.c
src/tsdb/src/tsdbRead.c
+3
-0
src/util/src/ttokenizer.c
src/util/src/ttokenizer.c
+4
-0
tests/pytest/fulltest.sh
tests/pytest/fulltest.sh
+1
-0
tests/pytest/insert/restfulInsert.py
tests/pytest/insert/restfulInsert.py
+27
-13
tests/pytest/insert/special_character_show.py
tests/pytest/insert/special_character_show.py
+59
-0
tests/pytest/tag_lite/3.py
tests/pytest/tag_lite/3.py
+222
-222
tests/pytest/tag_lite/4.py
tests/pytest/tag_lite/4.py
+328
-329
tests/pytest/tag_lite/5.py
tests/pytest/tag_lite/5.py
+383
-385
tests/pytest/tag_lite/6.py
tests/pytest/tag_lite/6.py
+464
-466
tests/pytest/tag_lite/bigint.py
tests/pytest/tag_lite/bigint.py
+78
-80
tests/pytest/tag_lite/binary.py
tests/pytest/tag_lite/binary.py
+78
-80
tests/pytest/tag_lite/binary_binary.py
tests/pytest/tag_lite/binary_binary.py
+103
-105
tests/pytest/tag_lite/bool.py
tests/pytest/tag_lite/bool.py
+78
-80
tests/pytest/tag_lite/bool_binary.py
tests/pytest/tag_lite/bool_binary.py
+103
-105
tests/pytest/tag_lite/bool_int.py
tests/pytest/tag_lite/bool_int.py
+103
-105
tests/pytest/tag_lite/double.py
tests/pytest/tag_lite/double.py
+78
-80
tests/pytest/tag_lite/float.py
tests/pytest/tag_lite/float.py
+78
-80
tests/pytest/tag_lite/int.py
tests/pytest/tag_lite/int.py
+78
-80
tests/pytest/tag_lite/int_binary.py
tests/pytest/tag_lite/int_binary.py
+103
-105
tests/pytest/tag_lite/int_float.py
tests/pytest/tag_lite/int_float.py
+103
-105
tests/pytest/tag_lite/smallint.py
tests/pytest/tag_lite/smallint.py
+78
-80
tests/pytest/tag_lite/tinyint.py
tests/pytest/tag_lite/tinyint.py
+78
-80
tests/pytest/tag_lite/unsignedBigint.py
tests/pytest/tag_lite/unsignedBigint.py
+78
-80
tests/pytest/tag_lite/unsignedInt.py
tests/pytest/tag_lite/unsignedInt.py
+78
-80
tests/pytest/tag_lite/unsignedSmallint.py
tests/pytest/tag_lite/unsignedSmallint.py
+78
-80
tests/pytest/tag_lite/unsignedTinyint.py
tests/pytest/tag_lite/unsignedTinyint.py
+78
-80
未找到文件。
src/balance/src/bnMain.c
浏览文件 @
6ea659d1
...
...
@@ -220,10 +220,6 @@ int32_t bnAllocVnodes(SVgObj *pVgroup) {
}
static
bool
bnCheckVgroupReady
(
SVgObj
*
pVgroup
,
SVnodeGid
*
pRmVnode
)
{
if
(
pVgroup
->
lbTime
+
5
*
tsStatusInterval
>
tsAccessSquence
)
{
return
false
;
}
int32_t
rmVnodeVer
=
0
;
for
(
int32_t
i
=
0
;
i
<
pVgroup
->
numOfVnodes
;
++
i
)
{
SVnodeGid
*
pVnode
=
pVgroup
->
vnodeGid
+
i
;
...
...
@@ -405,7 +401,7 @@ void bnReset() {
if
(
pDnode
==
NULL
)
break
;
// while master change, should reset dnode to offline
mInfo
(
"dnode:%d set access:%
d
to 0"
,
pDnode
->
dnodeId
,
pDnode
->
lastAccess
);
mInfo
(
"dnode:%d set access:%
"
PRId64
"
to 0"
,
pDnode
->
dnodeId
,
pDnode
->
lastAccess
);
pDnode
->
lastAccess
=
0
;
if
(
pDnode
->
status
!=
TAOS_DN_STATUS_DROPPING
)
{
pDnode
->
status
=
TAOS_DN_STATUS_OFFLINE
;
...
...
@@ -499,7 +495,7 @@ static bool bnMontiorDropping() {
if
(
dnodeIsMasterEp
(
pDnode
->
dnodeEp
))
continue
;
if
(
mnodeGetDnodesNum
()
<=
1
)
continue
;
mLInfo
(
"dnode:%d, set to removing state for it offline:%
d
seconds"
,
pDnode
->
dnodeId
,
mLInfo
(
"dnode:%d, set to removing state for it offline:%
"
PRId64
"
seconds"
,
pDnode
->
dnodeId
,
tsAccessSquence
-
pDnode
->
lastAccess
);
pDnode
->
status
=
TAOS_DN_STATUS_DROPPING
;
...
...
@@ -574,8 +570,8 @@ void bnCheckStatus() {
if
(
pDnode
->
status
!=
TAOS_DN_STATUS_DROPPING
&&
pDnode
->
status
!=
TAOS_DN_STATUS_OFFLINE
)
{
pDnode
->
status
=
TAOS_DN_STATUS_OFFLINE
;
pDnode
->
offlineReason
=
TAOS_DN_OFF_STATUS_MSG_TIMEOUT
;
mInfo
(
"dnode:%d, set to offline state, access seq:%
d last seq:%d laststat:%d"
,
pDnode
->
dnodeId
,
tsAccessSquence
,
pDnode
->
lastAccess
,
pDnode
->
status
);
mInfo
(
"dnode:%d, set to offline state, access seq:%
"
PRId64
" last seq:%"
PRId64
" laststat:%d"
,
pDnode
->
dnodeId
,
tsAccessSquence
,
pDnode
->
lastAccess
,
pDnode
->
status
);
bnSetVgroupOffline
(
pDnode
);
bnStartTimer
(
3000
);
}
...
...
src/balance/src/bnThread.c
浏览文件 @
6ea659d1
...
...
@@ -102,12 +102,12 @@ static void bnProcessTimer(void *handle, void *tmrId) {
if
(
tsBnThread
.
stop
)
return
;
tsBnThread
.
timer
=
NULL
;
tsAccessSquence
++
;
bnStartTimer
(
-
1
);
bnCheckStatus
();
if
(
handle
==
NULL
)
{
++
tsAccessSquence
;
if
(
tsAccessSquence
%
tsBalanceInterval
==
0
)
{
mDebug
(
"balance function is scheduled by timer"
);
bnPostSignal
();
...
...
@@ -122,8 +122,7 @@ static void bnProcessTimer(void *handle, void *tmrId) {
void
bnStartTimer
(
int32_t
mseconds
)
{
if
(
tsBnThread
.
stop
)
return
;
bool
updateSoon
=
(
mseconds
!=
-
1
);
if
(
updateSoon
)
{
if
(
mseconds
!=
-
1
)
{
mTrace
(
"balance function will be called after %d ms"
,
mseconds
);
taosTmrReset
(
bnProcessTimer
,
mseconds
,
(
void
*
)(
int64_t
)
mseconds
,
tsMnodeTmr
,
&
tsBnThread
.
timer
);
}
else
{
...
...
@@ -132,5 +131,5 @@ void bnStartTimer(int32_t mseconds) {
}
void
bnNotify
()
{
bnStartTimer
(
500
);
bnStartTimer
(
500
);
}
src/client/src/tscSub.c
浏览文件 @
6ea659d1
...
...
@@ -264,7 +264,7 @@ static int tscUpdateSubscription(STscObj* pObj, SSub* pSub) {
SSqlCmd
*
pCmd
=
&
pSql
->
cmd
;
pSub
->
lastSyncTime
=
taosGetTimestampMs
(
);
TSDB_QUERY_CLEAR_TYPE
(
tscGetQueryInfoDetail
(
pCmd
,
0
)
->
type
,
TSDB_QUERY_TYPE_MULTITABLE_QUERY
);
STableMetaInfo
*
pTableMetaInfo
=
tscGetTableMetaInfoFromCmd
(
pCmd
,
pCmd
->
clauseIndex
,
0
);
if
(
UTIL_TABLE_IS_NORMAL_TABLE
(
pTableMetaInfo
))
{
...
...
@@ -275,6 +275,8 @@ static int tscUpdateSubscription(STscObj* pObj, SSub* pSub) {
taosArrayClear
(
pSub
->
progress
);
taosArrayPush
(
pSub
->
progress
,
&
target
);
}
pSub
->
lastSyncTime
=
taosGetTimestampMs
();
return
1
;
}
...
...
@@ -304,7 +306,11 @@ static int tscUpdateSubscription(STscObj* pObj, SSub* pSub) {
}
taosArrayDestroy
(
tables
);
TSDB_QUERY_SET_TYPE
(
tscGetQueryInfoDetail
(
pCmd
,
0
)
->
type
,
TSDB_QUERY_TYPE_MULTITABLE_QUERY
);
if
(
pTableMetaInfo
->
pVgroupTables
&&
taosArrayGetSize
(
pTableMetaInfo
->
pVgroupTables
)
>
0
)
{
TSDB_QUERY_SET_TYPE
(
tscGetQueryInfoDetail
(
pCmd
,
0
)
->
type
,
TSDB_QUERY_TYPE_MULTITABLE_QUERY
);
}
pSub
->
lastSyncTime
=
taosGetTimestampMs
();
return
1
;
}
...
...
src/mnode/inc/mnodeDef.h
浏览文件 @
6ea659d1
...
...
@@ -48,9 +48,8 @@ typedef struct SDnodeObj {
int32_t
dnodeId
;
int32_t
openVnodes
;
int64_t
createdTime
;
int
32_t
resever0
;
// from dnode status msg, config information
int
64_t
lastAccess
;
int32_t
customScore
;
// config by user
uint32_t
lastAccess
;
uint16_t
numOfCores
;
// from dnode status msg
uint16_t
dnodePort
;
char
dnodeFqdn
[
TSDB_FQDN_LEN
];
...
...
src/mnode/inc/mnodeDnode.h
浏览文件 @
6ea659d1
...
...
@@ -77,7 +77,7 @@ void * mnodeGetDnodeByEp(char *ep);
void
mnodeUpdateDnode
(
SDnodeObj
*
pDnode
);
int32_t
mnodeDropDnode
(
SDnodeObj
*
pDnode
,
void
*
pMsg
);
extern
int
32
_t
tsAccessSquence
;
extern
int
64
_t
tsAccessSquence
;
#ifdef __cplusplus
}
...
...
src/mnode/src/mnodeDnode.c
浏览文件 @
6ea659d1
...
...
@@ -39,8 +39,8 @@
#include "mnodePeer.h"
#include "mnodeCluster.h"
int
32_t
tsAccessSquence
=
0
;
int64_t
tsDnodeRid
=
-
1
;
int
64_t
tsAccessSquence
=
0
;
int64_t
tsDnodeRid
=
-
1
;
static
void
*
tsDnodeSdb
=
NULL
;
static
int32_t
tsDnodeUpdateSize
=
0
;
extern
void
*
tsMnodeSdb
;
...
...
@@ -567,7 +567,7 @@ static int32_t mnodeProcessDnodeStatusMsg(SMnodeMsg *pMsg) {
mnodeGetClusterId
());
return
TSDB_CODE_MND_INVALID_CLUSTER_ID
;
}
else
{
mTrace
(
"dnode:%d, status received, access times %
d
openVnodes:%d:%d"
,
pDnode
->
dnodeId
,
pDnode
->
lastAccess
,
mTrace
(
"dnode:%d, status received, access times %
"
PRId64
"
openVnodes:%d:%d"
,
pDnode
->
dnodeId
,
pDnode
->
lastAccess
,
htons
(
pStatus
->
openVnodes
),
pDnode
->
openVnodes
);
}
}
...
...
@@ -629,9 +629,9 @@ static int32_t mnodeProcessDnodeStatusMsg(SMnodeMsg *pMsg) {
bnNotify
();
}
i
f
(
!
tsEnableBalance
)
{
int32_t
numOfMnodes
=
mnodeGetMnodesNum
();
if
(
numOfMnodes
<
tsNumOfMnodes
)
bnNotify
();
i
nt32_t
numOfMnodes
=
mnodeGetMnodesNum
();
if
(
numOfMnodes
<
tsNumOfMnodes
&&
numOfMnodes
<
mnodeGetOnlineDnodesNum
()
&&
!
pDnode
->
isMgmt
)
{
bnNotify
();
}
if
(
openVnodes
!=
pDnode
->
openVnodes
)
{
...
...
src/tsdb/src/tsdbRead.c
浏览文件 @
6ea659d1
...
...
@@ -3319,6 +3319,9 @@ int32_t tsdbGetTableGroupFromIdList(STsdbRepo* tsdb, SArray* pTableIdList, STabl
if
(
pTable
->
type
==
TSDB_SUPER_TABLE
)
{
tsdbError
(
"direct query on super tale is not allowed, table uid:%"
PRIu64
", tid:%d"
,
id
->
uid
,
id
->
tid
);
terrno
=
TSDB_CODE_QRY_INVALID_MSG
;
tsdbUnlockRepoMeta
(
tsdb
);
taosArrayDestroy
(
group
);
return
terrno
;
}
tsdbRefTable
(
pTable
);
...
...
src/util/src/ttokenizer.c
浏览文件 @
6ea659d1
...
...
@@ -275,6 +275,10 @@ static int32_t tKeywordCode(const char* z, int n) {
}
}
if
(
keywordHashTable
==
NULL
)
{
return
TK_ILLEGAL
;
}
SKeyword
**
pKey
=
(
SKeyword
**
)
taosHashGet
(
keywordHashTable
,
key
,
n
);
return
(
pKey
!=
NULL
)
?
(
*
pKey
)
->
type
:
TK_ID
;
}
...
...
tests/pytest/fulltest.sh
浏览文件 @
6ea659d1
...
...
@@ -21,6 +21,7 @@ python3 insert/retentionpolicy.py
python3 ./test.py
-f
insert/alterTableAndInsert.py
python3 ./test.py
-f
insert/insertIntoTwoTables.py
python3 ./test.py
-f
insert/before_1970.py
python3 ./test.py
-f
insert/special_character_show.py
python3 bug2265.py
python3 ./test.py
-f
insert/bug3654.py
python3 ./test.py
-f
insert/insertDynamicColBeforeVal.py
...
...
tests/pytest/insert/restfulInsert.py
浏览文件 @
6ea659d1
...
...
@@ -40,12 +40,13 @@ class RestfulInsert:
if
tableID
+
i
>=
self
.
numOfTables
:
break
name
=
'beijing'
if
(
tableID
+
i
)
%
2
==
0
else
'shanghai'
data
=
"create table if not exists %s.%s%d using %s.meters tags(%d, '%s')"
%
(
self
.
dbname
,
self
.
tableNamePerfix
,
tableID
+
i
,
self
.
dbname
,
tableID
+
i
,
name
)
response
=
requests
.
post
(
self
.
url
,
data
,
headers
=
self
.
header
)
if
response
.
status_code
!=
200
:
print
(
response
.
content
)
try
:
response
=
requests
.
post
(
self
.
url
,
data
,
headers
=
self
.
header
)
if
response
.
status_code
!=
200
:
print
(
response
.
content
)
except
Exception
as
e
:
print
(
e
)
def
insertData
(
self
,
threadID
):
print
(
"thread %d started"
%
threadID
)
tablesPerThread
=
int
(
self
.
numOfTables
/
self
.
numOfThreads
)
...
...
@@ -90,10 +91,16 @@ class RestfulInsert:
if
len
(
data
)
>
1024
*
1024
:
print
(
'batch size is larger than 1M'
)
exit
(
-
1
)
response
=
requests
.
post
(
self
.
url
,
data
,
headers
=
self
.
header
)
if
response
.
status_code
!=
200
:
print
(
response
.
content
)
try
:
startTime
=
time
.
time
()
response
=
requests
.
post
(
self
.
url
,
data
,
headers
=
self
.
header
)
endTime
=
time
.
time
()
if
response
.
status_code
!=
200
:
print
(
response
.
content
)
else
:
print
(
"inserted %d records, %d seconds"
%
(
bloop
,
endTime
-
startTime
))
except
Exception
as
e
:
print
(
e
)
def
insertUnlimitedData
(
self
,
threadID
):
print
(
"thread %d started"
%
threadID
)
...
...
@@ -119,10 +126,17 @@ class RestfulInsert:
else
:
random
.
shuffle
(
values
)
for
k
in
range
(
len
(
values
)):
data
+=
values
[
k
]
response
=
requests
.
post
(
self
.
url
,
data
,
headers
=
self
.
header
)
if
response
.
status_code
!=
200
:
print
(
response
.
content
)
data
+=
values
[
k
]
try
:
startTime
=
time
.
time
()
response
=
requests
.
post
(
self
.
url
,
data
,
headers
=
self
.
header
)
endTime
=
time
.
time
()
if
response
.
status_code
!=
200
:
print
(
response
.
content
)
else
:
print
(
"inserted %d records, %d seconds"
%
(
self
.
batchSize
,
endTime
-
startTime
))
except
Exception
as
e
:
print
(
e
)
def
run
(
self
):
data
=
"create database if not exists %s"
%
self
.
dbname
...
...
tests/pytest/insert/special_character_show.py
0 → 100644
浏览文件 @
6ea659d1
###################################################################
# Copyright (c) 2016 by TAOS Technologies, Inc.
# All rights reserved.
#
# This file is proprietary and confidential to TAOS Technologies.
# No part of this file may be reproduced, stored, transmitted,
# disclosed or used in any form or by any means other than as
# expressly provided by the written permission from Jianhui Tao
#
###################################################################
# -*- coding: utf-8 -*-
import
sys
from
util.log
import
*
from
util.cases
import
*
from
util.sql
import
*
class
TDTestCase
:
def
init
(
self
,
conn
,
logSql
):
tdLog
.
debug
(
"start to execute %s"
%
__file__
)
tdSql
.
init
(
conn
.
cursor
(),
logSql
)
def
run
(
self
):
tdSql
.
prepare
()
# test case for https://jira.taosdata.com:18080/browse/TD-4584
#1
tdLog
.
info
(
'=============== step1,create stable'
)
tdLog
.
info
(
'create table stb1 (ts timestamp, value double) tags (bin binary(128))'
)
tdSql
.
execute
(
'create table stb1 (ts timestamp, value double) tags (bin binary(128))'
)
tdLog
.
info
(
'=============== step2,create table增加了转义字符'
)
tdLog
.
info
(
'create table tb1 using stb1 tags("abc
\\
"def")'
)
#增加了转义字符\
tdSql
.
execute
(
'create table tb1 using stb1 tags("abc
\\
"def")'
)
tdLog
.
info
(
'=============== step3,insert data'
)
tdLog
.
info
(
'insert into tb1 values(now,1.0)'
)
tdSql
.
execute
(
'insert into tb1 values(now,1.0)'
)
tdLog
.
info
(
'=============== step4,select table'
)
tdLog
.
info
(
'select * from stb1 '
)
tdSql
.
query
(
'select * from stb1 '
)
tdLog
.
info
(
'=============== step5,check data'
)
tdSql
.
checkData
(
0
,
2
,
'abc"def'
)
def
stop
(
self
):
tdSql
.
close
()
tdLog
.
success
(
"%s successfully executed"
%
__file__
)
tdCases
.
addWindows
(
__file__
,
TDTestCase
())
tdCases
.
addLinux
(
__file__
,
TDTestCase
())
tests/pytest/tag_lite/3.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/4.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/5.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/6.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/bigint.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/binary.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/binary_binary.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/bool.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/bool_binary.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/bool_int.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/double.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/float.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/int.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/int_binary.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/int_float.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/smallint.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/tinyint.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/unsignedBigint.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/unsignedInt.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/unsignedSmallint.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
tests/pytest/tag_lite/unsignedTinyint.py
浏览文件 @
6ea659d1
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录