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

#ifndef _TD_VNODE_H_
#define _TD_VNODE_H_

S
Shengliang Guan 已提交
19 20 21 22
#include "os.h"
#include "taosmsg.h"
#include "trpc.h"

S
Shengliang Guan 已提交
23 24 25 26
#ifdef __cplusplus
extern "C" {
#endif

S
Shengliang Guan 已提交
27 28 29
typedef struct SVnode SVnode;

typedef struct {
S
Shengliang Guan 已提交
30
  char       db[TSDB_FULL_DB_NAME_LEN];
S
Shengliang Guan 已提交
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
  int32_t    cacheBlockSize;  // MB
  int32_t    totalBlocks;
  int32_t    daysPerFile;
  int32_t    daysToKeep0;
  int32_t    daysToKeep1;
  int32_t    daysToKeep2;
  int32_t    minRowsPerFileBlock;
  int32_t    maxRowsPerFileBlock;
  int8_t     precision;  // time resolution
  int8_t     compression;
  int8_t     cacheLastRow;
  int8_t     update;
  int8_t     quorum;
  int8_t     replica;
  int8_t     walLevel;
  int32_t    fsyncPeriod;  // millisecond
  SVnodeDesc replicas[TSDB_MAX_REPLICA];
} SVnodeCfg;

S
Shengliang Guan 已提交
50 51 52 53 54 55 56 57
typedef enum {
  VN_MSG_TYPE_WRITE = 1,
  VN_MSG_TYPE_APPLY,
  VN_MSG_TYPE_SYNC,
  VN_MSG_TYPE_QUERY,
  VN_MSG_TYPE_FETCH
} EVMType;

S
Shengliang Guan 已提交
58
typedef struct {
S
Shengliang Guan 已提交
59 60 61
  int32_t curNum;
  int32_t allocNum;
  SRpcMsg rpcMsg[];
S
Shengliang Guan 已提交
62
} SVnodeMsg;
S
Shengliang Guan 已提交
63

S
Shengliang Guan 已提交
64 65 66 67 68 69 70
typedef struct {
  void (*SendMsgToDnode)(SEpSet *pEpSet, SRpcMsg *pMsg);
  void (*SendMsgToMnode)(SRpcMsg *pMsg);
  int32_t (*PutMsgIntoApplyQueue)(int32_t vgId, SVnodeMsg *pMsg);
} SVnodePara;

int32_t vnodeInit(SVnodePara);
S
Shengliang Guan 已提交
71
void    vnodeCleanup();
72

S
Shengliang Guan 已提交
73 74 75 76
SVnode *vnodeOpen(int32_t vgId, const char *path);
void    vnodeClose(SVnode *pVnode);
int32_t vnodeAlter(SVnode *pVnode, const SVnodeCfg *pCfg);
SVnode *vnodeCreate(int32_t vgId, const char *path, const SVnodeCfg *pCfg);
S
Shengliang Guan 已提交
77
void    vnodeDrop(SVnode *pVnode);
S
Shengliang Guan 已提交
78 79
int32_t vnodeCompact(SVnode *pVnode);
int32_t vnodeSync(SVnode *pVnode);
S
Shengliang Guan 已提交
80

S
Shengliang Guan 已提交
81
int32_t vnodeGetLoad(SVnode *pVnode, SVnodeLoad *pLoad);
S
Shengliang Guan 已提交
82 83 84 85 86

SVnodeMsg *vnodeInitMsg(int32_t msgNum);
int32_t    vnodeAppendMsg(SVnodeMsg *pMsg, SRpcMsg *pRpcMsg);
void       vnodeCleanupMsg(SVnodeMsg *pMsg);
void       vnodeProcessMsg(SVnode *pVnode, SVnodeMsg *pMsg, EVMType msgType);
S
Shengliang Guan 已提交
87

S
Shengliang Guan 已提交
88 89 90 91
#ifdef __cplusplus
}
#endif

92
#endif /*_TD_VNODE_H_*/