vnode.h 3.4 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_

H
refact  
Hongze Cheng 已提交
19 20 21 22 23 24
#include "os.h"
#include "trequest.h"

#include "meta.h"
#include "tq.h"
#include "tsdb.h"
S
Shengliang Guan 已提交
25

S
Shengliang Guan 已提交
26 27 28 29
#ifdef __cplusplus
extern "C" {
#endif

H
save  
Hongze Cheng 已提交
30 31 32 33 34 35 36 37
/* ------------------------ TYPES EXPOSED ------------------------ */
typedef struct SVnode        SVnode;
typedef struct SVnodeOptions SVnodeOptions;

/* ------------------------ SVnode ------------------------ */
SVnode *vnodeOpen(const char *path, const SVnodeOptions *pVnodeOptions);
void    vnodeClose(SVnode *pVnode);
void    vnodeDestroy(const char *path);
H
refact  
Hongze Cheng 已提交
38
int     vnodeProcessWriteReqs(SVnode *pVnode, SReqBatch *pReqBatch);
H
Hongze Cheng 已提交
39
int     vnodeApplyWriteRequest(SVnode *pVnode, const SRequest *pRequest);
H
refact  
Hongze Cheng 已提交
40 41
int     vnodeProcessReadReq(SVnode *pVnode, SRequest *pReq);
int     vnodeProcessSyncReq(SVnode *pVnode, SRequest *pReq);
H
save  
Hongze Cheng 已提交
42 43 44 45 46

/* ------------------------ SVnodeOptions ------------------------ */
void vnodeOptionsInit(SVnodeOptions *);
void vnodeOptionsClear(SVnodeOptions *);

H
refact  
Hongze Cheng 已提交
47 48 49 50 51 52 53 54
/* ------------------------ STRUCT DEFINITIONS ------------------------ */
struct SVnodeOptions {
  size_t       wsize;
  STsdbOptions tsdbOptions;
  SMetaOptions metaOptions;
  // STqOptions   tqOptions; // TODO
};

H
save  
Hongze Cheng 已提交
55 56
#if 1

H
Hongze Cheng 已提交
57
#include "taosmsg.h"
H
save  
Hongze Cheng 已提交
58
#include "trpc.h"
S
Shengliang Guan 已提交
59 60

typedef struct {
S
Shengliang Guan 已提交
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
  char     db[TSDB_FULL_DB_NAME_LEN];
  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   selfIndex;
  int8_t   walLevel;
  int32_t  fsyncPeriod;  // millisecond
S
Shengliang Guan 已提交
79
  SReplica replicas[TSDB_MAX_REPLICA];
S
Shengliang Guan 已提交
80 81
} SVnodeCfg;

S
Shengliang Guan 已提交
82 83 84 85 86 87
typedef enum {
  VN_MSG_TYPE_WRITE = 1,
  VN_MSG_TYPE_APPLY,
  VN_MSG_TYPE_SYNC,
  VN_MSG_TYPE_QUERY,
  VN_MSG_TYPE_FETCH
S
Shengliang Guan 已提交
88
} EVnMsgType;
S
Shengliang Guan 已提交
89

S
Shengliang Guan 已提交
90
typedef struct {
S
Shengliang Guan 已提交
91 92 93
  int32_t curNum;
  int32_t allocNum;
  SRpcMsg rpcMsg[];
S
Shengliang Guan 已提交
94
} SVnodeMsg;
S
Shengliang Guan 已提交
95

S
Shengliang Guan 已提交
96 97 98 99 100 101 102
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 已提交
103
void    vnodeCleanup();
104

S
Shengliang Guan 已提交
105 106
int32_t vnodeAlter(SVnode *pVnode, const SVnodeCfg *pCfg);
SVnode *vnodeCreate(int32_t vgId, const char *path, const SVnodeCfg *pCfg);
S
Shengliang Guan 已提交
107
void    vnodeDrop(SVnode *pVnode);
S
Shengliang Guan 已提交
108 109
int32_t vnodeCompact(SVnode *pVnode);
int32_t vnodeSync(SVnode *pVnode);
S
Shengliang Guan 已提交
110

S
Shengliang Guan 已提交
111
int32_t vnodeGetLoad(SVnode *pVnode, SVnodeLoad *pLoad);
S
Shengliang Guan 已提交
112 113 114 115

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

H
save  
Hongze Cheng 已提交
118 119
#endif

S
Shengliang Guan 已提交
120 121 122 123
#ifdef __cplusplus
}
#endif

124
#endif /*_TD_VNODE_H_*/