mndDef.h 7.7 KB
Newer Older
H
refact  
Hongze Cheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * 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/>.
 */

S
Shengliang Guan 已提交
16 17
#ifndef _TD_MND_DEF_H_
#define _TD_MND_DEF_H_
S
Shengliang Guan 已提交
18

19
#include "os.h"
S
Shengliang Guan 已提交
20 21 22 23
#include "taosmsg.h"
#include "tlog.h"
#include "trpc.h"
#include "ttimer.h"
S
Shengliang Guan 已提交
24
#include "thash.h"
S
Shengliang Guan 已提交
25
#include "cJSON.h"
S
Shengliang Guan 已提交
26
#include "mnode.h"
S
Shengliang Guan 已提交
27
#include "sync.h"
S
Shengliang Guan 已提交
28

S
Shengliang Guan 已提交
29 30 31
#ifdef __cplusplus
extern "C" {
#endif
S
Shengliang Guan 已提交
32

S
Shengliang Guan 已提交
33 34 35 36 37 38 39 40 41 42
extern int32_t mDebugFlag;

// mnode log function
#define mFatal(...) { if (mDebugFlag & DEBUG_FATAL) { taosPrintLog("MND FATAL ", 255, __VA_ARGS__); }}
#define mError(...) { if (mDebugFlag & DEBUG_ERROR) { taosPrintLog("MND ERROR ", 255, __VA_ARGS__); }}
#define mWarn(...)  { if (mDebugFlag & DEBUG_WARN)  { taosPrintLog("MND WARN ", 255, __VA_ARGS__); }}
#define mInfo(...)  { if (mDebugFlag & DEBUG_INFO)  { taosPrintLog("MND ", 255, __VA_ARGS__); }}
#define mDebug(...) { if (mDebugFlag & DEBUG_DEBUG) { taosPrintLog("MND ", mDebugFlag, __VA_ARGS__); }}
#define mTrace(...) { if (mDebugFlag & DEBUG_TRACE) { taosPrintLog("MND ", mDebugFlag, __VA_ARGS__); }}

43 44 45 46 47 48 49 50 51 52
typedef struct SClusterObj SClusterObj;
typedef struct SDnodeObj   SDnodeObj;
typedef struct SMnodeObj   SMnodeObj;
typedef struct SAcctObj    SAcctObj;
typedef struct SUserObj    SUserObj;
typedef struct SDbObj      SDbObj;
typedef struct SVgObj      SVgObj;
typedef struct SSTableObj  SSTableObj;
typedef struct SFuncObj    SFuncObj;
typedef struct SOperObj    SOperObj;
S
Shengliang Guan 已提交
53 54

typedef enum {
55 56 57 58 59 60 61 62
  MND_AUTH_ACCT_START = 0,
  MND_AUTH_ACCT_USER,
  MND_AUTH_ACCT_DNODE,
  MND_AUTH_ACCT_MNODE,
  MND_AUTH_ACCT_DB,
  MND_AUTH_ACCT_TABLE,
  MND_AUTH_ACCT_MAX
} EAuthAcct;
S
Shengliang Guan 已提交
63 64

typedef enum {
65 66 67 68 69 70
  MND_AUTH_OP_START = 0,
  MND_AUTH_OP_CREATE_USER,
  MND_AUTH_OP_ALTER_USER,
  MND_AUTH_OP_DROP_USER,
  MND_AUTH_MAX
} EAuthOp;
S
Shengliang Guan 已提交
71

S
Shengliang Guan 已提交
72 73 74 75 76 77 78 79 80 81
typedef enum {
  TRN_STAGE_PREPARE = 1,
  TRN_STAGE_EXECUTE = 2,
  TRN_STAGE_COMMIT = 3,
  TRN_STAGE_ROLLBACK = 4,
  TRN_STAGE_RETRY = 5
} ETrnStage;

typedef enum { TRN_POLICY_ROLLBACK = 1, TRN_POLICY_RETRY = 2 } ETrnPolicy;

S
Shengliang Guan 已提交
82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
typedef enum {
  DND_STATUS_OFFLINE = 0,
  DND_STATUS_READY = 1,
  DND_STATUS_CREATING = 2,
  DND_STATUS_DROPPING = 3
} EDndStatus;

typedef enum {
  DND_REASON_ONLINE = 0,
  DND_REASON_STATUS_MSG_TIMEOUT,
  DND_REASON_STATUS_NOT_RECEIVED,
  DND_REASON_VERSION_NOT_MATCH,
  DND_REASON_DNODE_ID_NOT_MATCH,
  DND_REASON_CLUSTER_ID_NOT_MATCH,
  DND_REASON_MN_EQUAL_VN_NOT_MATCH,
  DND_REASON_STATUS_INTERVAL_NOT_MATCH,
  DND_REASON_TIME_ZONE_NOT_MATCH,
  DND_REASON_LOCALE_NOT_MATCH,
  DND_REASON_CHARSET_NOT_MATCH,
  DND_REASON_OTHERS
} EDndReason;

S
Shengliang Guan 已提交
104 105 106 107
typedef struct STrans {
  int32_t    id;
  ETrnStage  stage;
  ETrnPolicy policy;
S
Shengliang Guan 已提交
108
  SMnode    *pMnode;
S
Shengliang Guan 已提交
109 110 111 112 113 114 115
  void      *rpcHandle;
  SArray    *redoLogs;
  SArray    *undoLogs;
  SArray    *commitLogs;
  SArray    *redoActions;
  SArray    *undoActions;
} STrans;
S
Shengliang Guan 已提交
116 117

typedef struct SClusterObj {
S
Shengliang Guan 已提交
118
  int32_t id;
S
Shengliang Guan 已提交
119
  char    name[TSDB_CLUSTER_ID_LEN];
S
Shengliang Guan 已提交
120 121 122 123 124
  int64_t createdTime;
  int64_t updateTime;
} SClusterObj;

typedef struct SDnodeObj {
S
Shengliang Guan 已提交
125 126 127 128
  int32_t    id;
  int64_t    createdTime;
  int64_t    updateTime;
  int64_t    rebootTime;
S
Shengliang Guan 已提交
129
  int32_t    accessTimes;
S
Shengliang Guan 已提交
130 131 132 133 134 135
  int16_t    numOfMnodes;
  int16_t    numOfVnodes;
  int16_t    numOfQnodes;
  int16_t    numOfSupportMnodes;
  int16_t    numOfSupportVnodes;
  int16_t    numOfSupportQnodes;
S
Shengliang Guan 已提交
136
  int16_t    numOfCores;
S
Shengliang Guan 已提交
137 138 139 140 141
  EDndStatus status;
  EDndReason offlineReason;
  uint16_t   port;
  char       fqdn[TSDB_FQDN_LEN];
  char       ep[TSDB_EP_LEN];
S
Shengliang Guan 已提交
142 143 144 145
} SDnodeObj;

typedef struct SMnodeObj {
  int32_t    id;
S
Shengliang Guan 已提交
146 147
  int64_t    createdTime;
  int64_t    updateTime;
S
Shengliang Guan 已提交
148
  ESyncState role;
S
Shengliang Guan 已提交
149 150
  int32_t    roleTerm;
  int64_t    roleTime;
151
  SDnodeObj *pDnode;
S
Shengliang Guan 已提交
152 153 154 155 156 157 158
} SMnodeObj;

typedef struct {
  int32_t maxUsers;
  int32_t maxDbs;
  int32_t maxTimeSeries;
  int32_t maxStreams;
S
Shengliang Guan 已提交
159 160
  int64_t maxStorage;   // In unit of GB
  int32_t accessState;  // Configured only by command
S
Shengliang Guan 已提交
161 162 163 164 165 166 167
} SAcctCfg;

typedef struct {
  int32_t numOfUsers;
  int32_t numOfDbs;
  int32_t numOfTimeSeries;
  int32_t numOfStreams;
S
Shengliang Guan 已提交
168 169
  int64_t totalStorage;  // Total storage wrtten from this account
  int64_t compStorage;   // Compressed storage on disk
S
Shengliang Guan 已提交
170 171 172 173 174 175 176
} SAcctInfo;

typedef struct SAcctObj {
  char      acct[TSDB_USER_LEN];
  int64_t   createdTime;
  int64_t   updateTime;
  int32_t   acctId;
S
Shengliang Guan 已提交
177
  int32_t   status;
S
Shengliang Guan 已提交
178 179 180 181 182 183 184 185 186 187
  SAcctCfg  cfg;
  SAcctInfo info;
} SAcctObj;

typedef struct SUserObj {
  char      user[TSDB_USER_LEN];
  char      pass[TSDB_KEY_LEN];
  char      acct[TSDB_USER_LEN];
  int64_t   createdTime;
  int64_t   updateTime;
S
Shengliang Guan 已提交
188 189 190 191
  int8_t    superAuth;
  int8_t    readAuth;
  int8_t    writeAuth;
  int32_t   acctId;
S
Shengliang Guan 已提交
192
  SHashObj *prohibitDbHash;
S
Shengliang Guan 已提交
193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218
} SUserObj;

typedef struct {
  int32_t cacheBlockSize;
  int32_t totalBlocks;
  int32_t maxTables;
  int32_t daysPerFile;
  int32_t daysToKeep0;
  int32_t daysToKeep1;
  int32_t daysToKeep2;
  int32_t minRowsPerFileBlock;
  int32_t maxRowsPerFileBlock;
  int32_t commitTime;
  int32_t fsyncPeriod;
  int8_t  precision;
  int8_t  compression;
  int8_t  walLevel;
  int8_t  replications;
  int8_t  quorum;
  int8_t  update;
  int8_t  cacheLastRow;
  int8_t  dbType;
  int16_t partitions;
} SDbCfg;

typedef struct SDbObj {
S
Shengliang Guan 已提交
219
  char      name[TSDB_FULL_DB_NAME_LEN];
S
Shengliang Guan 已提交
220 221 222 223
  char      acct[TSDB_USER_LEN];
  int64_t   createdTime;
  int64_t   updateTime;
  SDbCfg    cfg;
224
  int64_t   uid;
S
Shengliang Guan 已提交
225 226 227 228 229 230 231 232 233 234 235 236 237
  int8_t    status;
  int32_t   numOfVgroups;
  int32_t   numOfTables;
  int32_t   numOfSuperTables;
  int32_t   vgListSize;
  int32_t   vgListIndex;
  SVgObj  **vgList;
  SAcctObj *pAcct;
} SDbObj;

typedef struct {
  int32_t    dnodeId;
  int8_t     role;
238
  SDnodeObj *pDnode;
S
Shengliang Guan 已提交
239 240 241 242 243 244 245 246 247
} SVnodeGid;

typedef struct SVgObj {
  uint32_t  vgId;
  int32_t   numOfVnodes;
  int64_t   createdTime;
  int64_t   updateTime;
  int32_t   lbDnodeId;
  int32_t   lbTime;
S
Shengliang Guan 已提交
248
  char      dbName[TSDB_FULL_DB_NAME_LEN];
S
Shengliang Guan 已提交
249 250 251 252 253 254 255 256 257 258 259 260 261 262
  int8_t    inUse;
  int8_t    accessState;
  int8_t    status;
  SVnodeGid vnodeGid[TSDB_MAX_REPLICA];
  int32_t   vgCfgVersion;
  int8_t    compact;
  int32_t   numOfTables;
  int64_t   totalStorage;
  int64_t   compStorage;
  int64_t   pointsWritten;
  SDbObj   *pDb;
} SVgObj;

typedef struct SSTableObj {
263 264 265 266 267 268 269
  char     tableId[TSDB_TABLE_NAME_LEN];
  uint64_t uid;
  int64_t  createdTime;
  int64_t  updateTime;
  int32_t  numOfColumns;  // used by normal table
  int32_t  numOfTags;
  SSchema *schema;
S
Shengliang Guan 已提交
270 271 272 273 274
} SSTableObj;

typedef struct SFuncObj {
  char    name[TSDB_FUNC_NAME_LEN];
  int64_t createdTime;
S
Shengliang Guan 已提交
275 276 277 278 279 280 281 282 283 284 285 286
  int8_t  funcType;
  int8_t  scriptType;
  int8_t  align;
  int8_t  outputType;
  int32_t outputLen;
  int32_t bufSize;
  int64_t sigature;
  int32_t commentSize;
  int32_t codeSize;
  char   *pComment;
  char   *pCode;
  char    pData[];
S
Shengliang Guan 已提交
287 288
} SFuncObj;

S
Shengliang Guan 已提交
289 290 291 292 293 294 295 296 297 298 299 300 301 302 303
typedef struct {
  int32_t id;
  int8_t  type;
  int8_t  replica;
  int16_t numOfColumns;
  int32_t rowSize;
  int32_t numOfRows;
  int32_t numOfReads;
  int32_t payloadLen;
  void   *pIter;
  SMnode *pMnode;
  char    db[TSDB_FULL_DB_NAME_LEN];
  int16_t offset[TSDB_MAX_COLUMNS];
  int32_t bytes[TSDB_MAX_COLUMNS];
  char    payload[];
S
Shengliang Guan 已提交
304 305
} SShowObj;

S
Shengliang Guan 已提交
306
typedef struct SMnodeMsg {
S
Shengliang Guan 已提交
307
  char    user[TSDB_USER_LEN];
S
Shengliang Guan 已提交
308 309
  char    db[TSDB_FULL_DB_NAME_LEN];
  int32_t acctId;
310
  SMnode *pMnode;
S
Shengliang Guan 已提交
311 312 313 314 315 316 317 318 319
  int16_t received;
  int16_t successed;
  int16_t expected;
  int16_t retry;
  int32_t code;
  int64_t createdTime;
  SRpcMsg rpcMsg;
  int32_t contLen;
  void   *pCont;
S
Shengliang Guan 已提交
320
} SMnodeMsg;
S
Shengliang Guan 已提交
321

S
Shengliang Guan 已提交
322 323 324 325 326
typedef struct {
  int32_t id;
  void   *rpcHandle;
} STransMsg;

S
Shengliang Guan 已提交
327 328 329
#ifdef __cplusplus
}
#endif
S
Shengliang Guan 已提交
330

S
Shengliang Guan 已提交
331
#endif /*_TD_MND_DEF_H_*/