tsync.h 3.4 KB
Newer Older
J
Jeff Tao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * 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 TDENGINE_SYNC_H
#define TDENGINE_SYNC_H

#ifdef __cplusplus
extern "C" {
#endif

#define TAOS_SYNC_MAX_REPLICA 5

typedef enum _TAOS_SYNC_ROLE {
  TAOS_SYNC_ROLE_OFFLINE,
  TAOS_SYNC_ROLE_UNSYNCED,
  TAOS_SYNC_ROLE_SLAVE,
  TAOS_SYNC_ROLE_MASTER,
} ESyncRole;

typedef enum _TAOS_SYNC_STATUS {
  TAOS_SYNC_STATUS_INIT,
  TAOS_SYNC_STATUS_START,
  TAOS_SYNC_STATUS_FILE,
  TAOS_SYNC_STATUS_CACHE,
} ESyncStatus;

typedef struct {
  uint32_t  nodeId;    // node ID assigned by TDengine
  uint32_t  nodeIp;    // node IP address
  char      name[TSDB_FILENAME_LEN]; // external node name 
} SNodeInfo;

typedef struct {
  uint32_t   arbitratorIp;  // arbitrator IP address
  int8_t     quorum;    // number of confirms required, >=1 
  int8_t     replica;   // number of replications, >=1
  SNodeInfo  nodeInfo[TAOS_SYNC_MAX_REPLICA];
} SSyncCfg;
J
Jeff Tao 已提交
51 52 53 54 55 56 57

typedef struct {
  int       selfIndex;
  uint32_t  nodeId[TAOS_SYNC_MAX_REPLICA];
  int       role[TAOS_SYNC_MAX_REPLICA];  
} SNodesRole;
 
J
Jeff Tao 已提交
58 59 60
typedef struct {
  int32_t    vgId;      // vgroup ID
  uint64_t   version;   // initial version
61 62
  SSyncCfg   syncCfg;   // configuration from mgmt
  char       path[128]; // path to the file
J
Jeff Tao 已提交
63
 
64 65
  void      *ahandle;   // handle provided by APP 

J
Jeff Tao 已提交
66 67 68
  // if name is null, get the file from index or after, used by master
  // if name is provided, get the named file at the specified index, used by unsynced node
  // it returns the file magic number and size, if file not there, magic shall be 0.
J
Jeff Tao 已提交
69
  uint32_t   (*getFileInfo)(void *ahandle, char *name, uint32_t *index, int32_t *size); 
J
Jeff Tao 已提交
70 71 72

  // get the wal file from index or after
  // return value, -1: error, 1:more wal files, 0:last WAL. if name[0]==0, no WAL file
J
Jeff Tao 已提交
73
  int        (*getWalInfo)(void *ahandle, char *name, uint32_t *index); 
J
Jeff Tao 已提交
74 75
 
  // when a forward pkt is received, call this to handle data 
76
  int        (*writeToCache)(void *ahandle, void *pHead, int type);
J
Jeff Tao 已提交
77 78 79 80 81 82 83 84 85 86 87 88

  // when forward is confirmed by peer, master call this API to notify app
  void       (*confirmForward)(void *ahandle, void *mhandle, int32_t code);

  // when role is changed, call this to notify app
  void       (*notifyRole)(void *ahandle, int8_t role);
} SSyncInfo;

typedef void* tsync_h;

tsync_h syncStart(SSyncInfo *);
void    syncStop(tsync_h shandle);
89 90
int     syncReconfig(tsync_h shandle, SSyncCfg *);
int     syncForwardToPeer(tsync_h shandle, void *pHead, void *mhandle);
J
Jeff Tao 已提交
91 92 93 94 95 96
void    syncConfirmForward(tsync_h shandle, uint64_t version, int32_t code);
void    syncRecover(tsync_h shandle);      // recover from other nodes:
int     syncGetNodesRole(tsync_h shandle, SNodesRole *);

extern  char *syncRole[];

J
Jeff Tao 已提交
97
//global configurable parameters
J
Jeff Tao 已提交
98 99 100 101 102
extern  int   tsMaxSyncNum;
extern  int   tsSyncTcpThreads;
extern  int   tsMaxWatchFiles;
extern  short tsSyncPort;
extern  int   tsMaxFwdInfo; 
J
Jeff Tao 已提交
103
extern  int   sDebugFlag;
J
Jeff Tao 已提交
104 105 106 107 108 109

#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_SYNC_H