Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
72777848
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
72777848
编写于
11月 11, 2021
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refact
上级
84fb0da7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
68 addition
and
13 deletion
+68
-13
include/server/vnode/vnode.h
include/server/vnode/vnode.h
+64
-9
source/dnode/vnode/impl/src/vnodeWrite.c
source/dnode/vnode/impl/src/vnodeWrite.c
+4
-4
未找到文件。
include/server/vnode/vnode.h
浏览文件 @
72777848
...
...
@@ -17,9 +17,10 @@
#define _TD_VNODE_H_
#include "os.h"
#include "tr
equest
.h"
#include "tr
pc
.h"
#include "meta.h"
#include "tarray.h"
#include "tq.h"
#include "tsdb.h"
...
...
@@ -32,17 +33,71 @@ typedef struct SVnode SVnode;
typedef
struct
SVnodeOptions
SVnodeOptions
;
/* ------------------------ SVnode ------------------------ */
/**
* @brief Open a VNODE.
*
* @param path path of the vnode
* @param pVnodeOptions options of the vnode
* @return SVnode* The vnode object
*/
SVnode
*
vnodeOpen
(
const
char
*
path
,
const
SVnodeOptions
*
pVnodeOptions
);
void
vnodeClose
(
SVnode
*
pVnode
);
void
vnodeDestroy
(
const
char
*
path
);
int
vnodeProcessWriteReqs
(
SVnode
*
pVnode
,
SReqBatch
*
pReqBatch
);
int
vnodeApplyWriteRequest
(
SVnode
*
pVnode
,
const
SRequest
*
pRequest
);
int
vnodeProcessReadReq
(
SVnode
*
pVnode
,
SRequest
*
pReq
);
int
vnodeProcessSyncReq
(
SVnode
*
pVnode
,
SRequest
*
pReq
);
/**
* @brief Close a VNODE
*
* @param pVnode The vnode object
*/
void
vnodeClose
(
SVnode
*
pVnode
);
/**
* @brief Destroy a VNODE.
*
* @param path Path of the VNODE.
*/
void
vnodeDestroy
(
const
char
*
path
);
/**
* @brief Process an array of write messages.
*
* @param pVnode The vnode object.
* @param pMsgs The array of SRpcMsg
* @return int 0 for success, -1 for failure
*/
int
vnodeProcessWMsgs
(
SVnode
*
pVnode
,
SArray
*
pMsgs
);
/**
* @brief Apply a write request message.
*
* @param pVnode The vnode object.
* @param pMsg The request message
* @return int 0 for success, -1 for failure
*/
int
vnodeApplyWMsg
(
SVnode
*
pVnode
,
SRpcMsg
*
pMsg
,
SRpcMsg
**
pRsp
);
/**
* @brief Process the sync request
*
* @param pVnode
* @param pMsg
* @param pRsp
* @return int
*/
int
vnodeProcessSyncReq
(
SVnode
*
pVnode
,
SRpcMsg
*
pMsg
,
SRpcMsg
**
pRsp
);
/* ------------------------ SVnodeOptions ------------------------ */
void
vnodeOptionsInit
(
SVnodeOptions
*
);
void
vnodeOptionsClear
(
SVnodeOptions
*
);
/**
* @brief Initialize VNODE options.
*
* @param pOptions The options object to be initialized. It should not be NULL.
*/
void
vnodeOptionsInit
(
SVnodeOptions
*
pOptions
);
/**
* @brief Clear VNODE options.
*
* @param pOptions Options to clear.
*/
void
vnodeOptionsClear
(
SVnodeOptions
*
pOptions
);
/* ------------------------ STRUCT DEFINITIONS ------------------------ */
struct
SVnodeOptions
{
...
...
source/dnode/vnode/impl/src/vnodeWrite.c
浏览文件 @
72777848
...
...
@@ -15,24 +15,24 @@
#include "vnodeDef.h"
int
vnodeProcessW
riteReqs
(
SVnode
*
pVnode
,
SReqBatch
*
pReqBatch
)
{
int
vnodeProcessW
Msgs
(
SVnode
*
pVnode
,
SArray
*
pMsgs
)
{
/* TODO */
return
0
;
}
int
vnodeApplyW
riteRequest
(
SVnode
*
pVnode
,
const
SRequest
*
pRequest
)
{
int
vnodeApplyW
Msg
(
SVnode
*
pVnode
,
SRpcMsg
*
pMsg
,
SRpcMsg
**
pRsp
)
{
int
reqType
;
/* TODO */
size_t
reqSize
;
/* TODO */
uint64_t
reqVersion
=
0
;
/* TODO */
int
code
=
0
;
// Copy the request to vnode buffer
SRequest
*
pReq
=
mMalloc
(
pVnode
->
inuse
,
reqSize
);
void
*
pReq
=
mMalloc
(
pVnode
->
inuse
,
reqSize
);
if
(
pReq
==
NULL
)
{
// TODO: handle error
}
memcpy
(
pReq
,
p
Request
,
reqSize
);
memcpy
(
pReq
,
p
Msg
,
reqSize
);
// Push the request to TQ so consumers can consume
tqPushMsg
(
pVnode
->
pTq
,
pReq
,
0
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录