Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
44a893a1
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
Star
22018
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
44a893a1
编写于
6月 07, 2022
作者:
M
Minghao Li
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(sync): snapshot maybe change when sending
上级
a56f149a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
20 addition
and
15 deletion
+20
-15
source/libs/sync/src/syncAppendEntriesReply.c
source/libs/sync/src/syncAppendEntriesReply.c
+19
-15
source/libs/sync/src/syncMain.c
source/libs/sync/src/syncMain.c
+1
-0
未找到文件。
source/libs/sync/src/syncAppendEntriesReply.c
浏览文件 @
44a893a1
...
...
@@ -165,29 +165,33 @@ int32_t syncNodeOnAppendEntriesReplySnapshotCb(SSyncNode* ths, SyncAppendEntries
// has snapshot
if
(
syncNodeHasSnapshot
(
ths
))
{
SSnapshot
snapshot
;
ths
->
pFsm
->
FpGetSnapshot
(
ths
->
pFsm
,
&
snapshot
);
if
(
nextIndex
<=
snapshot
.
lastApplyIndex
)
{
// ASSERT(nextIndex == snapshot.lastApplyIndex);
// get sender
SSyncSnapshotSender
*
pSender
=
NULL
;
for
(
int
i
=
0
;
i
<
ths
->
replicaNum
;
++
i
)
{
if
(
syncUtilSameId
(
&
(
pMsg
->
srcId
),
&
((
ths
->
replicasId
)[
i
])))
{
pSender
=
(
ths
->
senders
)[
i
];
}
}
ASSERT
(
pSender
!=
NULL
);
nextIndex
=
snapshot
.
lastApplyIndex
+
1
;
sInfo
(
"reset new nextIndex %ld, snapshot.lastApplyIndex:%ld"
,
nextIndex
,
snapshot
.
lastApplyIndex
);
// calculate sentryIndex
SyncIndex
sentryIndex
;
if
(
pSender
->
start
)
{
sentryIndex
=
pSender
->
snapshot
.
lastApplyIndex
;
}
else
{
// start send snapshot
// get sender
SSyncSnapshotSender
*
pSender
=
NULL
;
for
(
int
i
=
0
;
i
<
ths
->
replicaNum
;
++
i
)
{
if
(
syncUtilSameId
(
&
(
pMsg
->
srcId
),
&
((
ths
->
replicasId
)[
i
])))
{
pSender
=
(
ths
->
senders
)[
i
];
}
}
ASSERT
(
pSender
!=
NULL
);
if
(
!
(
pSender
->
term
==
ths
->
pRaftStore
->
currentTerm
&&
pSender
->
finish
==
true
))
{
snapshotSenderStart
(
pSender
);
}
else
{
sInfo
(
"snapshot send finish, send_term:%lu, current_term:%lu"
,
pSender
->
term
,
ths
->
pRaftStore
->
currentTerm
);
}
sentryIndex
=
pSender
->
snapshot
.
lastApplyIndex
;
}
// update nextIndex to sentryIndex + 1
if
(
nextIndex
<=
sentryIndex
)
{
nextIndex
=
sentryIndex
+
1
;
}
}
...
...
source/libs/sync/src/syncMain.c
浏览文件 @
44a893a1
...
...
@@ -1693,6 +1693,7 @@ const char* syncStr(ESyncState state) {
int32_t
syncNodeCommit
(
SSyncNode
*
ths
,
SyncIndex
beginIndex
,
SyncIndex
endIndex
,
uint64_t
flag
)
{
int32_t
code
=
0
;
sInfo
(
"sync commit from %ld to %ld, flag:0x%lX"
,
beginIndex
,
endIndex
,
flag
);
// maybe execute by leader, skip snapshot
SSnapshot
snapshot
=
{.
data
=
NULL
,
.
lastApplyIndex
=
-
1
,
.
lastApplyTerm
=
0
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录