Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
7722f880
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
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看板
未验证
提交
7722f880
编写于
8月 08, 2022
作者:
L
Li Minghao
提交者:
GitHub
8月 08, 2022
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #15861 from taosdata/feature/3.0_mhli
refactor(sync): speed up replicate
上级
313e7259
df18cc5f
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
84 addition
and
42 deletion
+84
-42
include/libs/sync/sync.h
include/libs/sync/sync.h
+5
-1
include/util/tdef.h
include/util/tdef.h
+3
-3
source/dnode/vnode/src/vnd/vnodeSync.c
source/dnode/vnode/src/vnd/vnodeSync.c
+2
-1
source/libs/sync/inc/syncInt.h
source/libs/sync/inc/syncInt.h
+7
-2
source/libs/sync/inc/syncReplication.h
source/libs/sync/inc/syncReplication.h
+1
-1
source/libs/sync/src/syncMain.c
source/libs/sync/src/syncMain.c
+33
-28
source/libs/sync/src/syncReplication.c
source/libs/sync/src/syncReplication.c
+32
-5
source/libs/sync/src/syncTimeout.c
source/libs/sync/src/syncTimeout.c
+1
-1
未找到文件。
include/libs/sync/sync.h
浏览文件 @
7722f880
...
...
@@ -26,7 +26,10 @@ extern "C" {
extern
bool
gRaftDetailLog
;
#define SYNC_RESP_TTL_MS 10000000
#define SYNC_RESP_TTL_MS 10000000
#define SYNC_SPEED_UP_HB_TIMER 400
#define SYNC_SPEED_UP_AFTER_MS (1000 * 20)
#define SYNC_SLOW_DOWN_RANGE 100
#define SYNC_MAX_BATCH_SIZE 1
#define SYNC_INDEX_BEGIN 0
...
...
@@ -205,6 +208,7 @@ int32_t syncSetStandby(int64_t rid);
ESyncState
syncGetMyRole
(
int64_t
rid
);
bool
syncIsReady
(
int64_t
rid
);
const
char
*
syncGetMyRoleStr
(
int64_t
rid
);
bool
syncRestoreFinish
(
int64_t
rid
);
SyncTerm
syncGetMyTerm
(
int64_t
rid
);
SyncGroupId
syncGetVgId
(
int64_t
rid
);
void
syncGetEpSet
(
int64_t
rid
,
SEpSet
*
pEpSet
);
...
...
include/util/tdef.h
浏览文件 @
7722f880
...
...
@@ -359,11 +359,11 @@ typedef enum ELogicConditionType {
#define TSDB_DEFAULT_DB_SCHEMALESS TSDB_DB_SCHEMALESS_OFF
#define TSDB_DB_MIN_WAL_RETENTION_PERIOD -1
#define TSDB_DEFAULT_DB_WAL_RETENTION_PERIOD
0
#define TSDB_DEFAULT_DB_WAL_RETENTION_PERIOD
(24 * 60 * 60 * 2)
#define TSDB_DB_MIN_WAL_RETENTION_SIZE -1
#define TSDB_DEFAULT_DB_WAL_RETENTION_SIZE
0
#define TSDB_DEFAULT_DB_WAL_RETENTION_SIZE
-1
#define TSDB_DB_MIN_WAL_ROLL_PERIOD 0
#define TSDB_DEFAULT_DB_WAL_ROLL_PERIOD
0
#define TSDB_DEFAULT_DB_WAL_ROLL_PERIOD
(24 * 60 * 60 * 1)
#define TSDB_DB_MIN_WAL_SEGMENT_SIZE 0
#define TSDB_DEFAULT_DB_WAL_SEGMENT_SIZE 0
...
...
source/dnode/vnode/src/vnd/vnodeSync.c
浏览文件 @
7722f880
...
...
@@ -730,7 +730,8 @@ void vnodeSyncClose(SVnode *pVnode) { syncStop(pVnode->sync); }
bool
vnodeIsLeader
(
SVnode
*
pVnode
)
{
if
(
!
syncIsReady
(
pVnode
->
sync
))
{
vDebug
(
"vgId:%d, vnode not ready"
,
pVnode
->
config
.
vgId
);
vDebug
(
"vgId:%d, vnode not ready, state:%s, restore:%d"
,
pVnode
->
config
.
vgId
,
syncGetMyRoleStr
(
pVnode
->
sync
),
syncRestoreFinish
(
pVnode
->
sync
));
return
false
;
}
...
...
source/libs/sync/inc/syncInt.h
浏览文件 @
7722f880
...
...
@@ -162,6 +162,9 @@ typedef struct SSyncNode {
// is config changing
bool
changing
;
int64_t
startTime
;
int64_t
lastReplicateTime
;
}
SSyncNode
;
// open/close --------------
...
...
@@ -186,16 +189,18 @@ int32_t syncNodePingAll(SSyncNode* pSyncNode);
// timer control --------------
int32_t
syncNodeStartPingTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeStopPingTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeStartElectTimer
(
SSyncNode
*
pSyncNode
,
int32_t
ms
);
int32_t
syncNodeStopElectTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeRestartElectTimer
(
SSyncNode
*
pSyncNode
,
int32_t
ms
);
int32_t
syncNodeResetElectTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeStartHeartbeatTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeStart
NowHeartbeatTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeStart
HeartbeatTimerNow
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeStartHeartbeatTimerMS
(
SSyncNode
*
pSyncNode
,
int32_t
ms
);
int32_t
syncNodeStopHeartbeatTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeRestartHeartbeatTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeRestart
NowHeartbeatTimer
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeRestart
HeartbeatTimerNow
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeRestartNowHeartbeatTimerMS
(
SSyncNode
*
pSyncNode
,
int32_t
ms
);
// utils --------------
...
...
source/libs/sync/inc/syncReplication.h
浏览文件 @
7722f880
...
...
@@ -55,7 +55,7 @@ int32_t syncNodeAppendEntriesPeers(SSyncNode* pSyncNode);
int32_t
syncNodeAppendEntriesPeersSnapshot
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeAppendEntriesPeersSnapshot2
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeReplicate
(
SSyncNode
*
pSyncNode
);
int32_t
syncNodeReplicate
(
SSyncNode
*
pSyncNode
,
bool
isTimer
);
int32_t
syncNodeAppendEntries
(
SSyncNode
*
pSyncNode
,
const
SRaftId
*
destRaftId
,
const
SyncAppendEntries
*
pMsg
);
int32_t
syncNodeAppendEntriesBatch
(
SSyncNode
*
pSyncNode
,
const
SRaftId
*
destRaftId
,
const
SyncAppendEntriesBatch
*
pMsg
);
...
...
source/libs/sync/src/syncMain.c
浏览文件 @
7722f880
...
...
@@ -495,6 +495,18 @@ const char* syncGetMyRoleStr(int64_t rid) {
return
s
;
}
bool
syncRestoreFinish
(
int64_t
rid
)
{
SSyncNode
*
pSyncNode
=
(
SSyncNode
*
)
taosAcquireRef
(
tsNodeRefId
,
rid
);
if
(
pSyncNode
==
NULL
)
{
return
false
;
}
ASSERT
(
rid
==
pSyncNode
->
rid
);
bool
restoreFinish
=
pSyncNode
->
restoreFinish
;
taosReleaseRef
(
tsNodeRefId
,
pSyncNode
->
rid
);
return
restoreFinish
;
}
SyncTerm
syncGetMyTerm
(
int64_t
rid
)
{
SSyncNode
*
pSyncNode
=
(
SSyncNode
*
)
taosAcquireRef
(
tsNodeRefId
,
rid
);
if
(
pSyncNode
==
NULL
)
{
...
...
@@ -1086,6 +1098,10 @@ SSyncNode* syncNodeOpen(const SSyncInfo* pOldSyncInfo) {
// start raft
// syncNodeBecomeFollower(pSyncNode);
int64_t
timeNow
=
taosGetTimestampMs
();
pSyncNode
->
startTime
=
timeNow
;
pSyncNode
->
lastReplicateTime
=
timeNow
;
syncNodeEventLog
(
pSyncNode
,
"sync open"
);
return
pSyncNode
;
...
...
@@ -1303,7 +1319,7 @@ int32_t syncNodeResetElectTimer(SSyncNode* pSyncNode) {
return
ret
;
}
int32_t
syncNode
StartHeartbeatTimer
(
SSyncNode
*
pSyncNode
)
{
static
int32_t
syncNodeDo
StartHeartbeatTimer
(
SSyncNode
*
pSyncNode
)
{
int32_t
ret
=
0
;
if
(
syncEnvIsStart
())
{
taosTmrReset
(
pSyncNode
->
FpHeartbeatTimerCB
,
pSyncNode
->
heartbeatTimerMS
,
pSyncNode
,
gSyncEnv
->
pTimerManager
,
...
...
@@ -1322,26 +1338,21 @@ int32_t syncNodeStartHeartbeatTimer(SSyncNode* pSyncNode) {
return
ret
;
}
int32_t
syncNodeStartHeartbeatTimerMS
(
SSyncNode
*
pSyncNode
,
int32_t
ms
)
{
int32_t
ret
=
0
;
if
(
syncEnvIsStart
())
{
taosTmrReset
(
pSyncNode
->
FpHeartbeatTimerCB
,
ms
,
pSyncNode
,
gSyncEnv
->
pTimerManager
,
&
pSyncNode
->
pHeartbeatTimer
);
atomic_store_64
(
&
pSyncNode
->
heartbeatTimerLogicClock
,
pSyncNode
->
heartbeatTimerLogicClockUser
);
}
else
{
sError
(
"vgId:%d, start heartbeat timer error, sync env is stop"
,
pSyncNode
->
vgId
);
}
do
{
char
logBuf
[
128
];
snprintf
(
logBuf
,
sizeof
(
logBuf
),
"start heartbeat timer, ms:%d"
,
ms
);
syncNodeEventLog
(
pSyncNode
,
logBuf
);
}
while
(
0
);
int32_t
syncNodeStartHeartbeatTimer
(
SSyncNode
*
pSyncNode
)
{
pSyncNode
->
heartbeatTimerMS
=
pSyncNode
->
hbBaseLine
;
int32_t
ret
=
syncNodeDoStartHeartbeatTimer
(
pSyncNode
);
return
ret
;
}
int32_t
syncNodeStartHeartbeatTimerMS
(
SSyncNode
*
pSyncNode
,
int32_t
ms
)
{
pSyncNode
->
heartbeatTimerMS
=
ms
;
int32_t
ret
=
syncNodeDoStartHeartbeatTimer
(
pSyncNode
);
return
ret
;
}
int32_t
syncNodeStartNowHeartbeatTimer
(
SSyncNode
*
pSyncNode
)
{
int32_t
ret
=
syncNodeStartHeartbeatTimerMS
(
pSyncNode
,
1
);
int32_t
syncNodeStartHeartbeatTimerNow
(
SSyncNode
*
pSyncNode
)
{
pSyncNode
->
heartbeatTimerMS
=
1
;
int32_t
ret
=
syncNodeDoStartHeartbeatTimer
(
pSyncNode
);
return
ret
;
}
...
...
@@ -1362,9 +1373,9 @@ int32_t syncNodeRestartHeartbeatTimer(SSyncNode* pSyncNode) {
return
0
;
}
int32_t
syncNodeRestart
NowHeartbeatTimer
(
SSyncNode
*
pSyncNode
)
{
int32_t
syncNodeRestart
HeartbeatTimerNow
(
SSyncNode
*
pSyncNode
)
{
syncNodeStopHeartbeatTimer
(
pSyncNode
);
syncNodeStart
NowHeartbeatTimer
(
pSyncNode
);
syncNodeStart
HeartbeatTimerNow
(
pSyncNode
);
return
0
;
}
...
...
@@ -1942,9 +1953,6 @@ void syncNodeDoConfigChange(SSyncNode* pSyncNode, SSyncCfg* pNewConfig, SyncInde
// Raft 3.6.2 Committing entries from previous terms
syncNodeAppendNoop
(
pSyncNode
);
#if 0 // simon
syncNodeReplicate(pSyncNode);
#endif
syncMaybeAdvanceCommitIndex
(
pSyncNode
);
}
else
{
...
...
@@ -2126,9 +2134,6 @@ void syncNodeCandidate2Leader(SSyncNode* pSyncNode) {
// Raft 3.6.2 Committing entries from previous terms
syncNodeAppendNoop
(
pSyncNode
);
#if 0 // simon
syncNodeReplicate(pSyncNode);
#endif
syncMaybeAdvanceCommitIndex
(
pSyncNode
);
}
...
...
@@ -2499,7 +2504,7 @@ static int32_t syncNodeAppendNoop(SSyncNode* ths) {
if
(
ths
->
state
==
TAOS_SYNC_STATE_LEADER
)
{
int32_t
code
=
ths
->
pLogStore
->
syncLogAppendEntry
(
ths
->
pLogStore
,
pEntry
);
ASSERT
(
code
==
0
);
syncNodeReplicate
(
ths
);
syncNodeReplicate
(
ths
,
false
);
}
syncEntryDestory
(
pEntry
);
...
...
@@ -2572,7 +2577,7 @@ int32_t syncNodeOnClientRequestCb(SSyncNode* ths, SyncClientRequest* pMsg, SyncI
// if mulit replica, start replicate right now
if
(
ths
->
replicaNum
>
1
)
{
syncNodeReplicate
(
ths
);
syncNodeReplicate
(
ths
,
false
);
// pre commit
syncNodePreCommit
(
ths
,
pEntry
,
0
);
...
...
@@ -2641,7 +2646,7 @@ int32_t syncNodeOnClientRequestBatchCb(SSyncNode* ths, SyncClientRequestBatch* p
if
(
ths
->
replicaNum
>
1
)
{
// if multi replica, start replicate right now
syncNodeReplicate
(
ths
);
syncNodeReplicate
(
ths
,
false
);
}
else
if
(
ths
->
replicaNum
==
1
)
{
// one replica
...
...
source/libs/sync/src/syncReplication.c
浏览文件 @
7722f880
...
...
@@ -202,17 +202,19 @@ int32_t syncNodeAppendEntriesPeersSnapshot2(SSyncNode* pSyncNode) {
syncAppendEntriesBatchDestroy
(
pMsg
);
// speed up
if
(
pMsg
->
dataCount
>
0
&&
p
Msg
->
prevLogIndex
<
pSyncNode
->
commitIndex
)
{
if
(
pMsg
->
dataCount
>
0
&&
p
SyncNode
->
commitIndex
-
pMsg
->
prevLogIndex
>
SYNC_SLOW_DOWN_RANGE
)
{
ret
=
1
;
#if 0
do {
char logBuf[128];
char host[64];
uint16_t port;
syncUtilU642Addr(pDestId->addr, host, sizeof(host), &port);
snprintf
(
logBuf
,
sizeof
(
logBuf
),
"speed up for %s:%d, pre-index:%ld"
,
host
,
port
,
pMsg
->
prevLogIndex
);
snprintf(logBuf, sizeof(logBuf), "
maybe
speed up for %s:%d, pre-index:%ld", host, port, pMsg->prevLogIndex);
syncNodeEventLog(pSyncNode, logBuf);
} while (0);
#endif
}
}
...
...
@@ -301,7 +303,7 @@ int32_t syncNodeAppendEntriesPeersSnapshot(SSyncNode* pSyncNode) {
return
ret
;
}
int32_t
syncNodeReplicate
(
SSyncNode
*
pSyncNode
)
{
int32_t
syncNodeReplicate
(
SSyncNode
*
pSyncNode
,
bool
isTimer
)
{
// start replicate
int32_t
ret
=
0
;
...
...
@@ -323,13 +325,38 @@ int32_t syncNodeReplicate(SSyncNode* pSyncNode) {
break
;
}
if
(
ret
>
0
)
{
// start delay
int64_t
timeNow
=
taosGetTimestampMs
();
int64_t
startDelay
=
timeNow
-
pSyncNode
->
startTime
;
// replicate delay
int64_t
replicateDelay
=
timeNow
-
pSyncNode
->
lastReplicateTime
;
pSyncNode
->
lastReplicateTime
=
timeNow
;
if
(
ret
>
0
&&
isTimer
&&
startDelay
>
SYNC_SPEED_UP_AFTER_MS
)
{
// speed up replicate
int32_t
ms
=
pSyncNode
->
heartbeatTimerMS
<
50
?
pSyncNode
->
heartbeatTimerMS
:
50
;
int32_t
ms
=
pSyncNode
->
heartbeatTimerMS
<
SYNC_SPEED_UP_HB_TIMER
?
pSyncNode
->
heartbeatTimerMS
:
SYNC_SPEED_UP_HB_TIMER
;
syncNodeRestartNowHeartbeatTimerMS
(
pSyncNode
,
ms
);
#if 0
do {
char logBuf[128];
snprintf(logBuf, sizeof(logBuf), "replicate speed up");
syncNodeEventLog(pSyncNode, logBuf);
} while (0);
#endif
}
else
{
syncNodeRestartHeartbeatTimer
(
pSyncNode
);
#if 0
do {
char logBuf[128];
snprintf(logBuf, sizeof(logBuf), "replicate slow down");
syncNodeEventLog(pSyncNode, logBuf);
} while (0);
#endif
}
return
ret
;
...
...
source/libs/sync/src/syncTimeout.c
浏览文件 @
7722f880
...
...
@@ -58,7 +58,7 @@ int32_t syncNodeOnTimeoutCb(SSyncNode* ths, SyncTimeout* pMsg) {
++
(
ths
->
heartbeatTimerCounter
);
sInfo
(
"vgId:%d, sync timeout, type:replicate count:%d, heartbeatTimerLogicClockUser:%ld"
,
ths
->
vgId
,
ths
->
heartbeatTimerCounter
,
ths
->
heartbeatTimerLogicClockUser
);
syncNodeReplicate
(
ths
);
syncNodeReplicate
(
ths
,
true
);
}
}
else
{
sError
(
"vgId:%d, unknown timeout-type:%d"
,
ths
->
vgId
,
pMsg
->
timeoutType
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录