Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
9f5943c4
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看板
未验证
提交
9f5943c4
编写于
6月 11, 2021
作者:
S
Shengliang Guan
提交者:
GitHub
6月 11, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #6442 from taosdata/fix/TD-4599
[TD-4599]<fix>: fix false dnode offline
上级
c7d7133f
b0fb8f9d
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
16 addition
and
22 deletion
+16
-22
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/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/balance/src/bnMain.c
浏览文件 @
9f5943c4
...
...
@@ -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
浏览文件 @
9f5943c4
...
...
@@ -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/mnode/inc/mnodeDef.h
浏览文件 @
9f5943c4
...
...
@@ -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
浏览文件 @
9f5943c4
...
...
@@ -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
浏览文件 @
9f5943c4
...
...
@@ -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
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录