Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
b405855b
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看板
提交
b405855b
编写于
4月 13, 2023
作者:
C
cadem
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
balance leader to enterprise
上级
e214f93d
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
9 addition
and
47 deletion
+9
-47
source/dnode/mnode/impl/CMakeLists.txt
source/dnode/mnode/impl/CMakeLists.txt
+1
-0
source/dnode/mnode/impl/src/mndVgroup.c
source/dnode/mnode/impl/src/mndVgroup.c
+8
-47
未找到文件。
source/dnode/mnode/impl/CMakeLists.txt
浏览文件 @
b405855b
...
...
@@ -5,6 +5,7 @@ ENDIF ()
IF
(
TD_ENTERPRISE
)
LIST
(
APPEND MNODE_SRC
${
TD_ENTERPRISE_DIR
}
/src/plugins/privilege/src/privilege.c
)
LIST
(
APPEND MNODE_SRC
${
TD_ENTERPRISE_DIR
}
/src/plugins/mnode/src/mndDb.c
)
LIST
(
APPEND MNODE_SRC
${
TD_ENTERPRISE_DIR
}
/src/plugins/mnode/src/mndVgroup.c
)
ENDIF
()
add_library
(
mnode STATIC
${
MNODE_SRC
}
)
...
...
source/dnode/mnode/impl/src/mndVgroup.c
浏览文件 @
b405855b
...
...
@@ -1891,56 +1891,17 @@ int32_t mndAddVgroupBalanceToTrans(SMnode *pMnode, SVgObj *pVgroup, STrans *pTra
return
0
;
}
int32_t
mndProcessVgroupBalanceLeaderMsg
(
SRpcMsg
*
pReq
)
{
int32_t
code
=
-
1
;
SBalanceVgroupLeaderReq
req
=
{
0
};
if
(
tDeserializeSBalanceVgroupLeaderReq
(
pReq
->
pCont
,
pReq
->
contLen
,
&
req
)
!=
0
)
{
terrno
=
TSDB_CODE_INVALID_MSG
;
return
code
;
}
SMnode
*
pMnode
=
pReq
->
info
.
node
;
SSdb
*
pSdb
=
pMnode
->
pSdb
;
int32_t
total
=
sdbGetSize
(
pSdb
,
SDB_VGROUP
);
if
(
total
<=
0
)
{
terrno
=
TSDB_CODE_TSC_INVALID_OPERATION
;
return
code
;
}
STrans
*
pTrans
=
NULL
;
pTrans
=
mndTransCreate
(
pMnode
,
TRN_POLICY_RETRY
,
TRN_CONFLICT_NOTHING
,
pReq
,
"bal-vg-leader"
);
if
(
pTrans
==
NULL
)
goto
_OVER
;
mndTransSetSerial
(
pTrans
);
mInfo
(
"trans:%d, used to balance vgroup leader"
,
pTrans
->
id
);
void
*
pIter
=
NULL
;
int32_t
count
=
0
;
while
(
1
)
{
SVgObj
*
pVgroup
=
NULL
;
pIter
=
sdbFetch
(
pSdb
,
SDB_VGROUP
,
pIter
,
(
void
**
)
&
pVgroup
);
if
(
pIter
==
NULL
)
break
;
if
(
mndAddVgroupBalanceToTrans
(
pMnode
,
pVgroup
,
pTrans
)
==
0
){
count
++
;
}
extern
int32_t
mndProcessVgroupBalanceLeaderMsgImp
(
SRpcMsg
*
pReq
);
sdbRelease
(
pSdb
,
pVgroup
);
}
if
(
count
==
0
)
{
terrno
=
TSDB_CODE_TSC_INVALID_OPERATION
;
goto
_OVER
;
}
if
(
mndTransPrepare
(
pMnode
,
pTrans
)
!=
0
)
goto
_OVER
;
code
=
0
;
int32_t
mndProcessVgroupBalanceLeaderMsg
(
SRpcMsg
*
pReq
)
{
return
mndProcessVgroupBalanceLeaderMsgImp
(
pReq
);
}
_OVER:
mndTransDrop
(
pTrans
);
return
code
;
#ifndef TD_ENTERPRISE
int32_t
mndProcessVgroupBalanceLeaderMsgImp
(
SRpcMsg
*
pReq
)
{
return
0
;
}
#endif
static
int32_t
mndCheckDnodeMemory
(
SMnode
*
pMnode
,
SDbObj
*
pOldDb
,
SDbObj
*
pNewDb
,
SVgObj
*
pOldVgroup
,
SVgObj
*
pNewVgroup
,
SArray
*
pArray
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录