Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
22a85734
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
22a85734
编写于
3月 05, 2023
作者:
H
Haojun Liao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mq): add more chek for balance couner to avoid the negative value emerges.
上级
b0c06c55
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
42 addition
and
24 deletion
+42
-24
include/util/taoserror.h
include/util/taoserror.h
+0
-1
source/client/src/clientTmq.c
source/client/src/clientTmq.c
+1
-6
source/client/test/clientTests.cpp
source/client/test/clientTests.cpp
+8
-1
source/dnode/mnode/impl/src/mndConsumer.c
source/dnode/mnode/impl/src/mndConsumer.c
+18
-6
source/dnode/mnode/impl/src/mndMain.c
source/dnode/mnode/impl/src/mndMain.c
+3
-0
source/dnode/mnode/impl/src/mndSubscribe.c
source/dnode/mnode/impl/src/mndSubscribe.c
+3
-3
source/dnode/vnode/src/tq/tqRead.c
source/dnode/vnode/src/tq/tqRead.c
+4
-5
source/libs/executor/src/scanoperator.c
source/libs/executor/src/scanoperator.c
+5
-1
source/util/src/terror.c
source/util/src/terror.c
+0
-1
未找到文件。
include/util/taoserror.h
浏览文件 @
22a85734
...
...
@@ -558,7 +558,6 @@ int32_t* taosGetErrno();
#define TSDB_CODE_TQ_GROUP_NOT_SET TAOS_DEF_ERROR_CODE(0, 0x0A0B)
#define TSDB_CODE_TQ_TABLE_SCHEMA_NOT_FOUND TAOS_DEF_ERROR_CODE(0, 0x0A0C)
#define TSDB_CODE_TQ_NO_COMMITTED_OFFSET TAOS_DEF_ERROR_CODE(0, 0x0A0D)
#define TSDB_CODE_TQ_NO_SUBSCRIBE_TOPICS TAOS_DEF_ERROR_CODE(0, 0x0A0E)
// wal
// #define TSDB_CODE_WAL_APP_ERROR TAOS_DEF_ERROR_CODE(0, 0x1000) // 2.x
...
...
source/client/src/clientTmq.c
浏览文件 @
22a85734
...
...
@@ -1076,12 +1076,7 @@ int32_t tmq_subscribe(tmq_t* tmq, const tmq_list_t* topic_list) {
SCMSubscribeReq
req
=
{
0
};
int32_t
code
=
0
;
if
(
sz
==
0
)
{
tscDebug
(
"consumer:0x%"
PRIx64
" cgroup:%s, subscribe %d topics, not allowed"
,
tmq
->
consumerId
,
tmq
->
groupId
,
sz
);
return
TSDB_CODE_TQ_NO_SUBSCRIBE_TOPICS
;
}
else
{
tscDebug
(
"consumer:0x%"
PRIx64
" cgroup:%s, subscribe %d topics"
,
tmq
->
consumerId
,
tmq
->
groupId
,
sz
);
}
tscDebug
(
"consumer:0x%"
PRIx64
" cgroup:%s, subscribe %d topics"
,
tmq
->
consumerId
,
tmq
->
groupId
,
sz
);
req
.
consumerId
=
tmq
->
consumerId
;
tstrncpy
(
req
.
clientId
,
tmq
->
clientId
,
256
);
...
...
source/client/test/clientTests.cpp
浏览文件 @
22a85734
...
...
@@ -925,7 +925,7 @@ TEST(clientCase, subscription_test) {
// 创建订阅 topics 列表
tmq_list_t
*
topicList
=
tmq_list_new
();
tmq_list_append
(
topicList
,
"topic_t1"
);
//
tmq_list_append(topicList, "topic_t1");
// 启动订阅
tmq_subscribe
(
tmq
,
topicList
);
...
...
@@ -938,6 +938,8 @@ TEST(clientCase, subscription_test) {
int32_t
msgCnt
=
0
;
int32_t
timeout
=
5000
;
int32_t
count
=
0
;
while
(
1
)
{
TAOS_RES
*
pRes
=
tmq_consumer_poll
(
tmq
,
timeout
);
if
(
pRes
)
{
...
...
@@ -952,6 +954,11 @@ TEST(clientCase, subscription_test) {
printf
(
"db: %s
\n
"
,
dbName
);
printf
(
"vgroup id: %d
\n
"
,
vgroupId
);
if
(
count
++
>
20
)
{
tmq_unsubscribe
(
tmq
);
break
;
}
while
(
1
)
{
TAOS_ROW
row
=
taos_fetch_row
(
pRes
);
if
(
row
==
NULL
)
break
;
...
...
source/dnode/mnode/impl/src/mndConsumer.c
浏览文件 @
22a85734
...
...
@@ -82,18 +82,29 @@ bool mndRebTryStart() {
}
void
mndRebEnd
()
{
int32_t
val
=
atomic_sub_fetch_32
(
&
mqRebInExecCnt
,
1
);
mInfo
(
"rebalance end, rebalance count:%d"
,
val
);
mndRebCntDec
();
}
void
mndRebCntInc
()
{
int32_t
val
=
atomic_add_fetch_32
(
&
mqRebInExecCnt
,
1
);
mInfo
(
"rebalance trans start, rebalance count:%d"
,
val
);
mInfo
(
"rebalance trans start, rebalance count
er
:%d"
,
val
);
}
void
mndRebCntDec
()
{
int32_t
val
=
atomic_sub_fetch_32
(
&
mqRebInExecCnt
,
1
);
mInfo
(
"rebalance trans end, rebalance count:%d"
,
val
);
while
(
1
)
{
int32_t
val
=
atomic_load_32
(
&
mqRebInExecCnt
);
if
(
val
<=
0
)
{
mError
(
"rebalance trans end, rebalance counter:%d should not be less equalled than 0, ignore counter desc"
,
val
);
break
;
}
int32_t
newVal
=
val
-
1
;
int32_t
oldVal
=
atomic_val_compare_exchange_32
(
&
mqRebInExecCnt
,
val
,
newVal
);
if
(
oldVal
==
val
)
{
mInfo
(
"rebalance trans end, rebalance counter:%d"
,
newVal
);
break
;
}
}
}
static
int32_t
mndProcessConsumerLostMsg
(
SRpcMsg
*
pMsg
)
{
...
...
@@ -308,6 +319,7 @@ static int32_t mndProcessMqTimerMsg(SRpcMsg *pMsg) {
taosRUnLockLatch
(
&
pConsumer
->
lock
);
}
else
if
(
status
==
MQ_CONSUMER_STATUS__MODIFY
)
{
taosRLockLatch
(
&
pConsumer
->
lock
);
int32_t
newTopicNum
=
taosArrayGetSize
(
pConsumer
->
rebNewTopics
);
for
(
int32_t
i
=
0
;
i
<
newTopicNum
;
i
++
)
{
char
key
[
TSDB_SUBSCRIBE_KEY_LEN
];
...
...
@@ -700,6 +712,7 @@ int32_t mndProcessSubscribeReq(SRpcMsg *pMsg) {
// no topics need to be rebalanced
if
(
taosArrayGetSize
(
pConsumerNew
->
rebNewTopics
)
==
0
&&
taosArrayGetSize
(
pConsumerNew
->
rebRemovedTopics
)
==
0
)
{
// mInfo();
goto
_over
;
}
...
...
@@ -1057,7 +1070,6 @@ static int32_t mndRetrieveConsumer(SRpcMsg *pReq, SShowObj *pShow, SSDataBlock *
}
taosRLockLatch
(
&
pConsumer
->
lock
);
mDebug
(
"showing consumer:0x%"
PRIx64
,
pConsumer
->
consumerId
);
int32_t
topicSz
=
taosArrayGetSize
(
pConsumer
->
assignedTopics
);
...
...
source/dnode/mnode/impl/src/mndMain.c
浏览文件 @
22a85734
...
...
@@ -706,6 +706,9 @@ int32_t mndProcessRpcMsg(SRpcMsg *pMsg) {
}
else
if
(
code
==
0
)
{
mGTrace
(
"msg:%p, successfully processed"
,
pMsg
);
}
else
{
if
(
code
==
-
1
)
{
code
=
terrno
;
}
mGError
(
"msg:%p, failed to process since %s, app:%p type:%s"
,
pMsg
,
tstrerror
(
code
),
pMsg
->
info
.
ahandle
,
TMSG_INFO
(
pMsg
->
msgType
));
}
...
...
source/dnode/mnode/impl/src/mndSubscribe.c
浏览文件 @
22a85734
...
...
@@ -263,7 +263,7 @@ static int32_t mndDoRebalance(SMnode *pMnode, const SMqRebInputObj *pInput, SMqR
imbConsumerNum
=
totalVgNum
%
afterRebConsumerNum
;
}
mInfo
(
"sub:%s mq re-balance %d consumers: at least %d vg
each, %d consumer has more vg
"
,
sub
,
mInfo
(
"sub:%s mq re-balance %d consumers: at least %d vg
s each, %d consumers has more vgs
"
,
sub
,
afterRebConsumerNum
,
minVgCnt
,
imbConsumerNum
);
// 4. first scan: remove consumer more than wanted, put to remove hash
...
...
@@ -591,13 +591,13 @@ static int32_t mndProcessRebalanceReq(SRpcMsg *pMsg) {
rebOutput
.
pSub
=
mndCreateSubscription
(
pMnode
,
pTopic
,
pRebInfo
->
key
);
if
(
rebOutput
.
pSub
==
NULL
)
{
mError
(
"mq rebalance %s failed create sub since %s,
abort
"
,
pRebInfo
->
key
,
terrstr
());
mError
(
"mq rebalance %s failed create sub since %s,
ignore
"
,
pRebInfo
->
key
,
terrstr
());
taosRUnLockLatch
(
&
pTopic
->
lock
);
mndReleaseTopic
(
pMnode
,
pTopic
);
continue
;
}
memcpy
(
rebOutput
.
pSub
->
dbName
,
pTopic
->
db
,
TSDB_DB_FNAME_LEN
);
memcpy
(
rebOutput
.
pSub
->
dbName
,
pTopic
->
db
,
TSDB_DB_FNAME_LEN
);
taosRUnLockLatch
(
&
pTopic
->
lock
);
mndReleaseTopic
(
pMnode
,
pTopic
);
...
...
source/dnode/vnode/src/tq/tqRead.c
浏览文件 @
22a85734
...
...
@@ -297,7 +297,7 @@ int32_t tqSeekVer(STqReader* pReader, int64_t ver, const char* id) {
tqError
(
"tmq poll: wal reader failed to seek to ver:%"
PRId64
" code:%s, %s"
,
ver
,
tstrerror
(
terrno
),
id
);
return
-
1
;
}
else
{
tq
Error
(
"tmq poll: wal reader seek to ver:%"
PRId64
" %s"
,
ver
,
id
);
tq
Debug
(
"tmq poll: wal reader seek to ver:%"
PRId64
" %s"
,
ver
,
id
);
return
0
;
}
}
...
...
@@ -308,13 +308,12 @@ int32_t tqNextBlock(STqReader* pReader, SFetchRet* ret) {
while
(
1
)
{
if
(
!
fromProcessedMsg
)
{
if
(
walNextValidMsg
(
pReader
->
pWalReader
)
<
0
)
{
pReader
->
ver
=
pReader
->
pWalReader
->
curVersion
-
pReader
->
pWalReader
->
curStopped
;
// pReader->pWalReader->curVersion - (pReader->pWalReader->curInvalid | pReader->pWalReader->curStopped);
pReader
->
ver
=
pReader
->
pWalReader
->
curVersion
-
pReader
->
pWalReader
->
curStopped
;
ret
->
offset
.
type
=
TMQ_OFFSET__LOG
;
ret
->
offset
.
version
=
pReader
->
ver
;
ret
->
fetchType
=
FETCH_TYPE__NONE
;
tqDebug
(
"return offset %"
PRId64
", no more valid"
,
ret
->
offset
.
version
);
tqDebug
(
"return offset %"
PRId64
", no more valid
msg in wal
"
,
ret
->
offset
.
version
);
return
-
1
;
}
...
...
source/libs/executor/src/scanoperator.c
浏览文件 @
22a85734
...
...
@@ -1632,8 +1632,12 @@ static SSDataBlock* doQueueScan(SOperatorInfo* pOperator) {
while
(
1
)
{
SFetchRet
ret
=
{
0
};
if
(
tqNextBlock
(
pInfo
->
tqReader
,
&
ret
)
<
0
)
{
qError
(
"failed to get next log block since %s"
,
terrstr
());
// if the end is reached, terrno is 0
if
(
terrno
!=
0
)
{
qError
(
"failed to get next log block since %s"
,
terrstr
());
}
}
if
(
ret
.
fetchType
==
FETCH_TYPE__DATA
)
{
blockDataCleanup
(
pInfo
->
pRes
);
setBlockIntoRes
(
pInfo
,
&
ret
.
data
,
true
);
...
...
source/util/src/terror.c
浏览文件 @
22a85734
...
...
@@ -436,7 +436,6 @@ TAOS_DEFINE_ERROR(TSDB_CODE_TQ_META_KEY_DUP_IN_TXN, "TQ met key dup in txn
TAOS_DEFINE_ERROR
(
TSDB_CODE_TQ_GROUP_NOT_SET
,
"TQ group not exist"
)
TAOS_DEFINE_ERROR
(
TSDB_CODE_TQ_TABLE_SCHEMA_NOT_FOUND
,
"TQ table schema not found"
)
TAOS_DEFINE_ERROR
(
TSDB_CODE_TQ_NO_COMMITTED_OFFSET
,
"TQ no committed offset"
)
TAOS_DEFINE_ERROR
(
TSDB_CODE_TQ_NO_SUBSCRIBE_TOPICS
,
"TQ no topics"
)
// wal
TAOS_DEFINE_ERROR
(
TSDB_CODE_WAL_FILE_CORRUPTED
,
"WAL file is corrupted"
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录