Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
83c403ff
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
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看板
提交
83c403ff
编写于
10月 25, 2021
作者:
L
Liu Jicong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add tq data structure
上级
c0dfa6cd
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
73 addition
and
39 deletion
+73
-39
include/server/vnode/tq/tq.h
include/server/vnode/tq/tq.h
+43
-14
source/server/vnode/src/vnodeReadMsg.c
source/server/vnode/src/vnodeReadMsg.c
+24
-1
source/server/vnode/tq/inc/tqInt.h
source/server/vnode/tq/inc/tqInt.h
+2
-20
source/server/vnode/tq/src/tq.c
source/server/vnode/tq/src/tq.c
+4
-4
未找到文件。
include/server/vnode/tq/tq.h
浏览文件 @
83c403ff
...
...
@@ -24,9 +24,10 @@ extern "C" {
typedef
struct
tmqMsgHead
{
int32_t
headLen
;
int32_t
msg
Ver
;
int32_t
proto
Ver
;
int64_t
cgId
;
int64_t
topicId
;
int64_t
clientId
;
int32_t
checksum
;
int32_t
msgType
;
}
tmqMsgHead
;
...
...
@@ -34,35 +35,43 @@ typedef struct tmqMsgHead {
//TODO: put msgs into common
typedef
struct
tmqConnectReq
{
tmqMsgHead
head
;
}
tmqConnectReq
;
typedef
struct
tmqConnectResp
{
tmqMsgHead
head
;
int8_t
status
;
}
tmqConnectResp
;
typedef
struct
tmqDisconnectReq
{
tmqMsgHead
head
;
}
tmqDisconnectReq
;
typedef
struct
tmqDisconnectResp
{
tmqMsgHead
head
;
int8_t
status
;
}
tmqDiconnectResp
;
typedef
struct
tmqConsumeReq
{
tmqMsgHead
head
;
int64_t
commitOffset
;
}
tmqConsumeReq
;
typedef
struct
tmqConsumeResp
{
tmqMsgHead
head
;
char
content
[];
}
tmqConsumeResp
;
typedef
struct
tmqSubscribeReq
{
//
typedef
struct
tmqMnodeSubscribeReq
{
tmqMsgHead
head
;
int64_t
topicLen
;
char
topic
[];
}
tmqSubscribeReq
;
typedef
struct
tmqSubscribeResp
{
typedef
struct
tmqMnodeSubscribeResp
{
tmqMsgHead
head
;
int64_t
vgId
;
char
ep
[];
//TSDB_EP_LEN
}
tmqSubscribeResp
;
typedef
struct
tmqHeartbeatReq
{
...
...
@@ -92,6 +101,24 @@ typedef struct STQ {
//value=consumeOffset: int64_t
}
STQ
;
#define TQ_BUFFER_SIZE 8
typedef
struct
tqBufferItem
{
int64_t
offset
;
void
*
executor
;
void
*
content
;
}
tqBufferItem
;
typedef
struct
tqGroupHandle
{
char
*
topic
;
//c style, end with '\0'
int64_t
cgId
;
void
*
ahandle
;
int64_t
consumeOffset
;
int32_t
head
;
int32_t
tail
;
tqBufferItem
buffer
[
TQ_BUFFER_SIZE
];
}
tqGroupHandle
;
//init in each vnode
STQ
*
tqInit
(
void
*
ref_func
(
void
*
),
void
*
unref_func
(
void
*
));
void
tqCleanUp
(
STQ
*
);
...
...
@@ -103,12 +130,14 @@ int tqCommit(STQ*);
//void* will be replace by a msg type
int
tqHandleConsumeMsg
(
STQ
*
,
tmqConsumeReq
*
msg
);
tqGroupHandle
*
tqFindGHandleBycId
(
STQ
*
,
int64_t
cId
);
int
tqOpenTCGroup
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
int64_t
cId
);
int
tqCloseTCGroup
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
int64_t
cId
);
int
tqMoveOffsetToNext
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
);
int
tqMoveOffsetToNext
(
tqGroupHandle
*
);
int
tqResetOffset
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
int64_t
offset
);
int
tqFetchMsg
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
);
int
tqRegisterContext
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
void
*
ahandle
);
int
tqFetchMsg
(
tqGroupHandle
*
,
void
*
);
int
tqRegisterContext
(
tqGroupHandle
*
,
void
*
);
int
tqLaunchQuery
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
void
*
query
);
int
tqSendLaunchQuery
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
void
*
query
);
...
...
source/server/vnode/src/vnodeReadMsg.c
浏览文件 @
83c403ff
...
...
@@ -218,10 +218,33 @@ int32_t vnodeProcessQueryMsg(SVnode *pVnode, SReadMsg *pRead) {
}
//mq related
int32_t
vnodeProcessConsumeMsg
(
SVnode
*
pVnode
,
SReadMsg
*
pRead
){
int32_t
vnodeProcessConsumeMsg
(
SVnode
*
pVnode
,
SReadMsg
*
pRead
)
{
//parse message and optionally move offset
void
*
pMsg
=
pRead
->
pCont
;
tmqConsumeReq
*
pConsumeMsg
=
(
tmqConsumeReq
*
)
pMsg
;
tmqMsgHead
msgHead
=
pConsumeMsg
->
head
;
//extract head
STQ
*
pTq
=
pVnode
->
pTQ
;
tqGroupHandle
*
pHandle
=
tqFindGHandleBycId
(
pTq
,
msgHead
.
clientId
);
//return msg if offset not moved
if
(
pConsumeMsg
->
commitOffset
==
pHandle
->
consumeOffset
)
{
//return msg
return
0
;
}
//or move offset
tqMoveOffsetToNext
(
pHandle
);
//fetch or register context
tqFetchMsg
(
pHandle
,
pRead
);
//judge mode, tail read or catch up read
//launch new query
return
0
;
}
int32_t
vnodeProcessTqQueryMsg
(
SVnode
*
pVnode
,
SReadMsg
*
pRead
)
{
//get operator tree from tq data structure
//execute operator tree
//put data into ringbuffer
//unref memory
return
0
;
}
//mq related end
...
...
source/server/vnode/tq/inc/tqInt.h
浏览文件 @
83c403ff
...
...
@@ -18,37 +18,19 @@
#include "tq.h"
#define TQ_BUFFER_SIZE 8
#ifdef __cplusplus
extern
"C"
{
#endif
typedef
struct
tqBufferItem
{
int64_t
offset
;
void
*
executor
;
void
*
content
;
}
tqBufferItem
;
typedef
struct
tqGroupHandle
{
char
*
topic
;
//c style, end with '\0'
int64_t
cgId
;
void
*
ahandle
;
int64_t
consumeOffset
;
int32_t
head
;
int32_t
tail
;
tqBufferItem
buffer
[
TQ_BUFFER_SIZE
];
}
tqGroupHandle
;
//create persistent storage for meta info such as consuming offset
//return value > 0: cgId
//return value <= 0: error code
int
tqCreateTCGroup
(
STQ
*
,
const
char
*
topic
,
int
cgId
,
tqGroupHandle
**
handle
);
//create ring buffer in memory and load consuming offset
int
tqOpenTCGroup
(
STQ
*
,
const
char
*
topic
,
int
cgId
);
//
int tqOpenTCGroup(STQ*, const char* topic, int cgId);
//destroy ring buffer and persist consuming offset
int
tqCloseTCGroup
(
STQ
*
,
const
char
*
topic
,
int
cgId
);
//
int tqCloseTCGroup(STQ*, const char* topic, int cgId);
//delete persistent storage for meta info
int
tqDropTCGroup
(
STQ
*
,
const
char
*
topic
,
int
cgId
);
...
...
source/server/vnode/tq/src/tq.c
浏览文件 @
83c403ff
...
...
@@ -22,7 +22,7 @@
//
//handle management message
static
tqGroupHandle
*
tqLookupGroupHandle
(
STQ
*
pTq
,
const
char
*
topic
,
int
cgId
)
{
tqGroupHandle
*
tqLookupGroupHandle
(
STQ
*
pTq
,
const
char
*
topic
,
int
cgId
)
{
//look in memory
//
//not found, try to restore from disk
...
...
@@ -56,9 +56,9 @@ int tqOpenTGroup(STQ* pTq, const char* topic, int cgId) {
return
0
;
}
int
tqCloseTCGroup
(
STQ
*
pTq
,
const
char
*
topic
,
int
cgId
)
{
tqGroupHandle
*
handle
=
tqLookupGroupHandle
(
pTq
,
topic
,
cgId
);
return
tqCommitTCGroup
(
handle
);
/*int tqCloseTCGroup(STQ* pTq, const char* topic, int cgId) {*/
/*tqGroupHandle* handle = tqLookupGroupHandle(pTq, topic, cgId);*/
/*return tqCommitTCGroup(handle);*/
}
int
tqDropTCGroup
(
STQ
*
pTq
,
const
char
*
topic
,
int
cgId
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录