sync.h 5.3 KB
Newer Older
S
Shengliang Guan 已提交
1
/*
M
Minghao Li 已提交
2
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
S
Shengliang Guan 已提交
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef _TD_LIBS_SYNC_H
#define _TD_LIBS_SYNC_H

#ifdef __cplusplus
extern "C" {
#endif

M
Minghao Li 已提交
23
#include "cJSON.h"
M
Minghao Li 已提交
24
#include "tdef.h"
S
Shengliang Guan 已提交
25
#include "tmsgcb.h"
S
Shengliang Guan 已提交
26

27 28 29
#define SYNC_INDEX_BEGIN 0
#define SYNC_INDEX_INVALID -1

M
Minghao Li 已提交
30
typedef uint64_t SyncNodeId;
S
Shengliang Guan 已提交
31 32 33 34
typedef int32_t  SyncGroupId;
typedef int64_t  SyncIndex;
typedef uint64_t SyncTerm;

35 36 37 38 39
typedef struct SSyncNode      SSyncNode;
typedef struct SSyncBuffer    SSyncBuffer;
typedef struct SWal           SWal;
typedef struct SSyncRaftEntry SSyncRaftEntry;

S
Shengliang Guan 已提交
40
typedef enum {
M
Minghao Li 已提交
41 42 43
  TAOS_SYNC_STATE_FOLLOWER = 100,
  TAOS_SYNC_STATE_CANDIDATE = 101,
  TAOS_SYNC_STATE_LEADER = 102,
M
Minghao Li 已提交
44
  TAOS_SYNC_STATE_ERROR = 103,
M
syncInt  
Minghao Li 已提交
45
} ESyncState;
S
Shengliang Guan 已提交
46

47 48 49 50 51 52 53 54 55 56 57
typedef enum {
  TAOS_SYNC_PROPOSE_SUCCESS = 0,
  TAOS_SYNC_PROPOSE_NOT_LEADER = 1,
  TAOS_SYNC_PROPOSE_OTHER_ERROR = 2,
} ESyncProposeCode;

typedef enum {
  TAOS_SYNC_FSM_CB_SUCCESS = 0,
  TAOS_SYNC_FSM_CB_OTHER_ERROR = 1,
} ESyncFsmCbCode;

M
Minghao Li 已提交
58
typedef struct SNodeInfo {
M
Minghao Li 已提交
59 60
  uint16_t nodePort;
  char     nodeFqdn[TSDB_FQDN_LEN];
S
Shengliang Guan 已提交
61 62
} SNodeInfo;

M
Minghao Li 已提交
63
typedef struct SSyncCfg {
M
Minghao Li 已提交
64
  int32_t   replicaNum;
M
Minghao Li 已提交
65
  int32_t   myIndex;
S
Shengliang Guan 已提交
66
  SNodeInfo nodeInfo[TSDB_MAX_REPLICA];
M
Minghao Li 已提交
67
} SSyncCfg;
S
Shengliang Guan 已提交
68

M
Minghao Li 已提交
69 70 71
typedef struct SSnapshot {
  void*     data;
  SyncIndex lastApplyIndex;
M
Minghao Li 已提交
72
  SyncTerm  lastApplyTerm;
M
Minghao Li 已提交
73
} SSnapshot;
S
Shengliang Guan 已提交
74

M
Minghao Li 已提交
75 76 77 78 79 80
typedef struct SFsmCbMeta {
  SyncIndex  index;
  bool       isWeak;
  int32_t    code;
  ESyncState state;
  uint64_t   seqNum;
81 82
  SyncTerm   term;
  SyncTerm   currentTerm;
83
  uint64_t   flag;
M
Minghao Li 已提交
84 85
} SFsmCbMeta;

86 87 88 89 90
typedef struct SReConfigCbMeta {
  int32_t   code;
  SyncIndex index;
  SyncTerm  term;
  SyncTerm  currentTerm;
M
Minghao Li 已提交
91 92 93
  SSyncCfg  oldCfg;
  bool      isDrop;
  uint64_t  flag;
94 95
} SReConfigCbMeta;

M
Minghao Li 已提交
96 97
typedef struct SSyncFSM {
  void* data;
98

M
Minghao Li 已提交
99 100 101
  void (*FpCommitCb)(struct SSyncFSM* pFsm, const SRpcMsg* pMsg, SFsmCbMeta cbMeta);
  void (*FpPreCommitCb)(struct SSyncFSM* pFsm, const SRpcMsg* pMsg, SFsmCbMeta cbMeta);
  void (*FpRollBackCb)(struct SSyncFSM* pFsm, const SRpcMsg* pMsg, SFsmCbMeta cbMeta);
102

103 104
  void (*FpRestoreFinishCb)(struct SSyncFSM* pFsm);
  int32_t (*FpGetSnapshot)(struct SSyncFSM* pFsm, SSnapshot* pSnapshot);
105

M
Minghao Li 已提交
106
  // if (*ppIter == NULL)
107
  //   *ppIter = new iter;
M
Minghao Li 已提交
108
  // else
109 110 111
  //   *ppIter.next();
  //
  // if success, return 0. else return error code
M
Minghao Li 已提交
112 113 114
  int32_t (*FpSnapshotRead)(struct SSyncFSM* pFsm, const SSnapshot* pSnapshot, void** ppIter, char** ppBuf,
                            int32_t* len);

115 116
  // apply data into fsm
  int32_t (*FpSnapshotApply)(struct SSyncFSM* pFsm, const SSnapshot* pSnapshot, char* pBuf, int32_t len);
117

118 119 120 121
  void (*FpReConfigCb)(struct SSyncFSM* pFsm, SSyncCfg newCfg, SReConfigCbMeta cbMeta);

  // int32_t (*FpRestoreSnapshot)(struct SSyncFSM* pFsm, const SSnapshot* snapshot);

S
Shengliang Guan 已提交
122 123
} SSyncFSM;

M
Minghao Li 已提交
124 125
// abstract definition of log store in raft
// SWal implements it
S
Shengliang Guan 已提交
126
typedef struct SSyncLogStore {
M
Minghao Li 已提交
127 128 129
  void* data;

  // append one log entry
M
Minghao Li 已提交
130
  int32_t (*appendEntry)(struct SSyncLogStore* pLogStore, SSyncRaftEntry* pEntry);
S
Shengliang Guan 已提交
131

M
Minghao Li 已提交
132
  // get one log entry, user need to free pEntry->pCont
M
Minghao Li 已提交
133
  SSyncRaftEntry* (*getEntry)(struct SSyncLogStore* pLogStore, SyncIndex index);
S
Shengliang Guan 已提交
134

M
Minghao Li 已提交
135 136
  // truncate log with index, entries after the given index (>=index) will be deleted
  int32_t (*truncate)(struct SSyncLogStore* pLogStore, SyncIndex fromIndex);
S
Shengliang Guan 已提交
137

M
Minghao Li 已提交
138 139 140 141 142
  // return index of last entry
  SyncIndex (*getLastIndex)(struct SSyncLogStore* pLogStore);

  // return term of last entry
  SyncTerm (*getLastTerm)(struct SSyncLogStore* pLogStore);
S
Shengliang Guan 已提交
143

M
Minghao Li 已提交
144 145 146 147 148 149
  // update log store commit index with "index"
  int32_t (*updateCommitIndex)(struct SSyncLogStore* pLogStore, SyncIndex index);

  // return commit index of log
  SyncIndex (*getCommitIndex)(struct SSyncLogStore* pLogStore);

S
Shengliang Guan 已提交
150 151
} SSyncLogStore;

M
Minghao Li 已提交
152
typedef struct SSyncInfo {
M
Minghao Li 已提交
153
  bool        isStandBy;
M
Minghao Li 已提交
154 155
  SyncGroupId vgId;
  SSyncCfg    syncCfg;
M
Minghao Li 已提交
156
  char        path[TSDB_FILENAME_LEN];
M
Minghao Li 已提交
157
  SWal*       pWal;
M
Minghao Li 已提交
158
  SSyncFSM*   pFsm;
S
Shengliang Guan 已提交
159 160 161
  SMsgCb*     msgcb;
  int32_t (*FpSendMsg)(const SEpSet* pEpSet, SRpcMsg* pMsg);
  int32_t (*FpEqMsg)(const SMsgCb* msgcb, SRpcMsg* pMsg);
S
Shengliang Guan 已提交
162 163
} SSyncInfo;

M
Minghao Li 已提交
164 165 166 167 168
int32_t     syncInit();
void        syncCleanUp();
int64_t     syncOpen(const SSyncInfo* pSyncInfo);
void        syncStart(int64_t rid);
void        syncStop(int64_t rid);
M
Minghao Li 已提交
169
int32_t     syncSetStandby(int64_t rid);
M
Minghao Li 已提交
170 171 172 173
int32_t     syncReconfig(int64_t rid, const SSyncCfg* pSyncCfg);
ESyncState  syncGetMyRole(int64_t rid);
const char* syncGetMyRoleStr(int64_t rid);
SyncTerm    syncGetMyTerm(int64_t rid);
M
Minghao Li 已提交
174
void        syncGetEpSet(int64_t rid, SEpSet* pEpSet);
M
Minghao Li 已提交
175
int32_t     syncGetVgId(int64_t rid);
176 177
int32_t     syncPropose(int64_t rid, const SRpcMsg* pMsg, bool isWeak);
bool        syncEnvIsStart();
M
Minghao Li 已提交
178
const char* syncStr(ESyncState state);
M
Minghao Li 已提交
179
bool        syncIsRestoreFinish(int64_t rid);
S
Shengliang Guan 已提交
180

M
Minghao Li 已提交
181 182 183 184
// to be moved to static
void syncStartNormal(int64_t rid);
void syncStartStandBy(int64_t rid);

S
Shengliang Guan 已提交
185 186 187 188 189
#ifdef __cplusplus
}
#endif

#endif /*_TD_LIBS_SYNC_H*/