Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
a0d8b7df
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看板
提交
a0d8b7df
编写于
10月 29, 2021
作者:
H
Haojun Liao
浏览文件
操作
浏览文件
下载
差异文件
Merge branch '3.0' of github.com:taosdata/tdengine into 3.0
上级
86b6c42c
4e902908
变更
24
隐藏空白更改
内联
并排
Showing
24 changed file
with
602 addition
and
327 deletion
+602
-327
include/common/taosmsg.h
include/common/taosmsg.h
+3
-2
include/libs/sync/sync.h
include/libs/sync/sync.h
+35
-38
include/libs/wal/wal.h
include/libs/wal/wal.h
+29
-29
include/server/vnode/tq/tq.h
include/server/vnode/tq/tq.h
+89
-90
source/libs/sync/src/sync.c
source/libs/sync/src/sync.c
+9
-2
source/libs/wal/CMakeLists.txt
source/libs/wal/CMakeLists.txt
+2
-2
source/libs/wal/src/wal.c
source/libs/wal/src/wal.c
+14
-2
source/server/mnode/inc/mnodeInt.h
source/server/mnode/inc/mnodeInt.h
+1
-1
source/server/mnode/src/mnodeTelem.c
source/server/mnode/src/mnodeTelem.c
+4
-3
source/server/mnode/src/mondeInt.c
source/server/mnode/src/mondeInt.c
+7
-5
source/server/vnode/inc/vnodeFile.h
source/server/vnode/inc/vnodeFile.h
+2
-2
source/server/vnode/inc/vnodeInt.h
source/server/vnode/inc/vnodeInt.h
+9
-14
source/server/vnode/meta/src/metaMain.c
source/server/vnode/meta/src/metaMain.c
+1
-0
source/server/vnode/src/vnodeFile.c
source/server/vnode/src/vnodeFile.c
+67
-51
source/server/vnode/src/vnodeMain.c
source/server/vnode/src/vnodeMain.c
+89
-5
source/server/vnode/src/vnodeMgmt.c
source/server/vnode/src/vnodeMgmt.c
+5
-4
source/server/vnode/src/vnodeReadMsg.c
source/server/vnode/src/vnodeReadMsg.c
+2
-2
source/server/vnode/tq/CMakeLists.txt
source/server/vnode/tq/CMakeLists.txt
+4
-3
source/server/vnode/tq/inc/tqCommit.h
source/server/vnode/tq/inc/tqCommit.h
+14
-0
source/server/vnode/tq/inc/tqInt.h
source/server/vnode/tq/inc/tqInt.h
+0
-1
source/server/vnode/tq/inc/tqMetaStore.h
source/server/vnode/tq/inc/tqMetaStore.h
+80
-0
source/server/vnode/tq/src/tq.c
source/server/vnode/tq/src/tq.c
+108
-71
source/server/vnode/tq/src/tqCommit.c
source/server/vnode/tq/src/tqCommit.c
+14
-0
source/server/vnode/tq/src/tqMetaStore.c
source/server/vnode/tq/src/tqMetaStore.c
+14
-0
未找到文件。
include/common/taosmsg.h
浏览文件 @
a0d8b7df
...
...
@@ -721,6 +721,8 @@ typedef struct {
int32_t
daysToKeep2
;
int32_t
minRowsPerFileBlock
;
int32_t
maxRowsPerFileBlock
;
int32_t
fsyncPeriod
;
int8_t
reserved
[
16
];
int8_t
precision
;
int8_t
compression
;
int8_t
cacheLastRow
;
...
...
@@ -728,8 +730,7 @@ typedef struct {
int8_t
walLevel
;
int8_t
replica
;
int8_t
quorum
;
int8_t
reserved
[
9
];
int32_t
fsyncPeriod
;
int8_t
selfIndex
;
SVnodeDesc
nodes
[
TSDB_MAX_REPLICA
];
}
SCreateVnodeMsg
,
SAlterVnodeMsg
;
...
...
include/libs/sync/sync.h
浏览文件 @
a0d8b7df
...
...
@@ -23,9 +23,9 @@ extern "C" {
#include <stdint.h>
#include "taosdef.h"
typedef
int
64_t
SyncNodeId
;
typedef
int32_t
SyncGroupId
;
typedef
int64_t
SyncIndex
;
typedef
int
32_t
SyncNodeId
;
typedef
int32_t
SyncGroupId
;
typedef
int64_t
SyncIndex
;
typedef
uint64_t
SSyncTerm
;
typedef
enum
{
...
...
@@ -41,41 +41,41 @@ typedef struct {
typedef
struct
{
SyncNodeId
nodeId
;
uint16_t
nodePort
;
// node sync Port
char
nodeFqdn
[
TSDB_FQDN_LEN
];
// node FQDN
uint16_t
nodePort
;
// node sync Port
char
nodeFqdn
[
TSDB_FQDN_LEN
];
// node FQDN
}
SNodeInfo
;
typedef
struct
{
int
selfIndex
;
int
nNode
;
SNodeInfo
*
nodeInfo
;
int
32_t
selfIndex
;
int
32_t
replica
;
SNodeInfo
nodeInfo
[
TSDB_MAX_REPLICA
]
;
}
SSyncCluster
;
typedef
struct
{
int32_t
selfIndex
;
int
nNode
;
SNodeInfo
*
node
;
ESyncRole
*
role
;
int32_t
selfIndex
;
int
32_t
replica
;
SNodeInfo
node
[
TSDB_MAX_REPLICA
]
;
ESyncRole
role
[
TSDB_MAX_REPLICA
]
;
}
SNodesRole
;
typedef
struct
SSyncFSM
{
void
*
pData
;
// apply committed log, bufs will be free by raft module
int
(
*
applyLog
)(
struct
SSyncFSM
*
fsm
,
SyncIndex
index
,
const
SSyncBuffer
*
buf
,
void
*
pData
);
int
32_t
(
*
applyLog
)(
struct
SSyncFSM
*
fsm
,
SyncIndex
index
,
const
SSyncBuffer
*
buf
,
void
*
pData
);
// cluster commit callback
int
(
*
onClusterChanged
)(
struct
SSyncFSM
*
fsm
,
const
SSyncCluster
*
cluster
,
void
*
pData
);
int
32_t
(
*
onClusterChanged
)(
struct
SSyncFSM
*
fsm
,
const
SSyncCluster
*
cluster
,
void
*
pData
);
// fsm return snapshot in ppBuf, bufs will be free by raft module
// TODO: getSnapshot SHOULD be async?
int
(
*
getSnapshot
)(
struct
SSyncFSM
*
fsm
,
SSyncBuffer
**
ppBuf
,
in
t
*
objId
,
bool
*
isLast
);
int
32_t
(
*
getSnapshot
)(
struct
SSyncFSM
*
fsm
,
SSyncBuffer
**
ppBuf
,
int32_
t
*
objId
,
bool
*
isLast
);
// fsm apply snapshot with pBuf data
int
(
*
applySnapshot
)(
struct
SSyncFSM
*
fsm
,
SSyncBuffer
*
pBuf
,
in
t
objId
,
bool
isLast
);
int
32_t
(
*
applySnapshot
)(
struct
SSyncFSM
*
fsm
,
SSyncBuffer
*
pBuf
,
int32_
t
objId
,
bool
isLast
);
// call when restore snapshot and log done
int
(
*
onRestoreDone
)(
struct
SSyncFSM
*
fsm
);
int
32_t
(
*
onRestoreDone
)(
struct
SSyncFSM
*
fsm
);
void
(
*
onRollback
)(
struct
SSyncFSM
*
fsm
,
SyncIndex
index
,
const
SSyncBuffer
*
buf
);
...
...
@@ -101,13 +101,13 @@ typedef struct SSyncLogStore {
typedef
struct
SSyncServerState
{
SyncNodeId
voteFor
;
SSyncTerm
term
;
SSyncTerm
term
;
}
SSyncServerState
;
typedef
struct
SSyncClusterConfig
{
// Log index number of current cluster config.
SyncIndex
index
;
// Log index number of previous cluster config.
SyncIndex
prevIndex
;
...
...
@@ -118,25 +118,21 @@ typedef struct SSyncClusterConfig {
typedef
struct
SStateManager
{
void
*
pData
;
void
(
*
saveServerState
)(
struct
SStateManager
*
stateMng
,
const
SSyncServerState
*
state
);
int32_t
(
*
saveServerState
)(
struct
SStateManager
*
stateMng
,
SSyncServerState
*
state
);
const
SSyncServerState
*
(
*
readServerState
)(
struct
SStateManager
*
stateMng
);
int32_t
(
*
readServerState
)(
struct
SStateManager
*
stateMng
,
SSyncServerState
*
state
);
void
(
*
saveCluster
)(
struct
SStateManager
*
stateMng
,
const
SSyncClusterConfig
*
cluster
);
//
void (*saveCluster)(struct SStateManager* stateMng, const SSyncClusterConfig* cluster);
const
SSyncClusterConfig
*
(
*
readCluster
)(
struct
SStateManager
*
stateMng
);
//
const SSyncClusterConfig* (*readCluster)(struct SStateManager* stateMng);
}
SStateManager
;
typedef
struct
{
SyncGroupId
vgId
;
SyncIndex
snapshotIndex
;
SSyncCluster
syncCfg
;
SSyncFSM
fsm
;
SyncGroupId
vgId
;
SyncIndex
snapshotIndex
;
SSyncCluster
syncCfg
;
SSyncFSM
fsm
;
SSyncLogStore
logStore
;
SStateManager
stateManager
;
}
SSyncInfo
;
...
...
@@ -146,19 +142,20 @@ typedef struct SSyncNode SSyncNode;
int32_t
syncInit
();
void
syncCleanUp
();
SSyncNode
syncStart
(
const
SSyncInfo
*
);
void
syncStop
(
SyncNodeId
);
SSyncNode
*
syncStart
(
const
SSyncInfo
*
);
void
syncReconfig
(
const
SSyncNode
*
,
const
SSyncCluster
*
);
void
syncStop
(
const
SSyncNode
*
);
int32_t
syncPropose
(
SSyncNode
syncNode
,
SSyncBuffer
buffer
,
void
*
pData
,
bool
isWeak
);
int32_t
syncPropose
(
SSyncNode
*
syncNode
,
SSyncBuffer
buffer
,
void
*
pData
,
bool
isWeak
);
int32_t
syncAddNode
(
SSyncNode
syncNode
,
const
SNodeInfo
*
pNode
);
//
int32_t syncAddNode(SSyncNode syncNode, const SNodeInfo *pNode);
int32_t
syncRemoveNode
(
SSyncNode
syncNode
,
const
SNodeInfo
*
pNode
);
//
int32_t syncRemoveNode(SSyncNode syncNode, const SNodeInfo *pNode);
extern
int32_t
syncDebugFlag
;
extern
int32_t
syncDebugFlag
;
#ifdef __cplusplus
}
#endif
#endif
/*_TD_LIBS_SYNC_H*/
#endif
/*_TD_LIBS_SYNC_H*/
include/libs/wal/wal.h
浏览文件 @
a0d8b7df
...
...
@@ -44,41 +44,41 @@ typedef struct {
EWalType
walLevel
;
// wal level
}
SWalCfg
;
typedef
void
*
twalh
;
// WAL HANDLE
typedef
int32_t
FWalWrite
(
void
*
ahandle
,
void
*
pHead
,
int32_t
qtype
,
void
*
pMsg
);
struct
SWal
;
typedef
struct
SWal
SWal
;
// WAL HANDLE
typedef
int32_t
(
*
FWalWrite
)(
void
*
ahandle
,
void
*
pHead
,
int32_t
qtype
,
void
*
pMsg
);
//module initialization
int32_t
walInit
();
void
walCleanUp
();
//
module initialization
int32_t
walInit
();
void
walCleanUp
();
//handle open and ctl
twalh
walOpen
(
char
*
path
,
SWalCfg
*
pCfg
);
int32_t
walAlter
(
twalh
,
SWalCfg
*
pCfg
);
void
walStop
(
twalh
);
void
walClose
(
twalh
);
// handle open and ctl
SWal
*
walOpen
(
char
*
path
,
SWalCfg
*
pCfg
);
int32_t
walAlter
(
SWal
*
,
SWalCfg
*
pCfg
);
void
walClose
(
SWal
*
);
//write
//
int64_t walWriteWithMsgType(twalh
, int8_t msgType, void* body, int32_t bodyLen);
int64_t
walWrite
(
twalh
,
void
*
body
,
int32_t
bodyLen
);
int64_t
walWriteBatch
(
twalh
,
void
**
bodies
,
int32_t
*
bodyLen
,
int32_t
batchSize
);
//
write
//
int64_t walWriteWithMsgType(SWal*
, int8_t msgType, void* body, int32_t bodyLen);
int64_t
walWrite
(
SWal
*
,
int64_t
index
,
void
*
body
,
int32_t
bodyLen
);
int64_t
walWriteBatch
(
SWal
*
,
void
**
bodies
,
int32_t
*
bodyLen
,
int32_t
batchSize
);
//apis for lifecycle management
void
walFsync
(
twalh
,
bool
force
);
int32_t
walCommit
(
twalh
,
int64_t
ver
);
//truncate after
int32_t
walRollback
(
twalh
,
int64_t
ver
);
//notify that previous log can be pruned safely
int32_t
walPrune
(
twalh
,
int64_t
ver
);
//
apis for lifecycle management
void
walFsync
(
SWal
*
,
bool
force
);
int32_t
walCommit
(
SWal
*
,
int64_t
ver
);
//
truncate after
int32_t
walRollback
(
SWal
*
,
int64_t
ver
);
//
notify that previous log can be pruned safely
int32_t
walPrune
(
SWal
*
,
int64_t
ver
);
//read
int32_t
walRead
(
twalh
,
SWalHead
**
,
int64_t
ver
);
int32_t
walReadWithFp
(
twalh
,
FWalWrite
writeFp
,
int64_t
verStart
,
in
t
readNum
);
//
read
int32_t
walRead
(
SWal
*
,
SWalHead
**
,
int64_t
ver
);
int32_t
walReadWithFp
(
SWal
*
,
FWalWrite
writeFp
,
int64_t
verStart
,
int32_
t
readNum
);
//lifecycle check
int32_t
walFirstVer
(
twalh
);
int32_t
walPersistedVer
(
twalh
);
int32_t
walLastVer
(
twalh
);
//
int32_t walDataCorrupted(twalh
);
//
lifecycle check
int32_t
walFirstVer
(
SWal
*
);
int32_t
walPersistedVer
(
SWal
*
);
int32_t
walLastVer
(
SWal
*
);
//
int32_t walDataCorrupted(SWal*
);
#ifdef __cplusplus
}
...
...
include/server/vnode/tq/tq.h
浏览文件 @
a0d8b7df
...
...
@@ -17,113 +17,114 @@
#define _TD_TQ_H_
#include "os.h"
#include "tutil.h"
#ifdef __cplusplus
extern
"C"
{
#endif
typedef
struct
t
mqMsgHead
{
typedef
struct
T
mqMsgHead
{
int32_t
protoVer
;
int32_t
msgType
;
int64_t
cgId
;
int64_t
clientId
;
}
t
mqMsgHead
;
}
T
mqMsgHead
;
typedef
struct
t
mqOneAck
{
typedef
struct
T
mqOneAck
{
int64_t
topicId
;
int64_t
consumeOffset
;
}
t
mqOneAck
;
}
T
mqOneAck
;
typedef
struct
t
mqAcks
{
typedef
struct
T
mqAcks
{
int32_t
ackNum
;
//should be sorted
t
mqOneAck
acks
[];
}
t
mqAcks
;
T
mqOneAck
acks
[];
}
T
mqAcks
;
//TODO: put msgs into common
typedef
struct
t
mqConnectReq
{
t
mqMsgHead
head
;
t
mqAcks
acks
;
}
t
mqConnectReq
;
typedef
struct
T
mqConnectReq
{
T
mqMsgHead
head
;
T
mqAcks
acks
;
}
T
mqConnectReq
;
typedef
struct
t
mqConnectRsp
{
t
mqMsgHead
head
;
typedef
struct
T
mqConnectRsp
{
T
mqMsgHead
head
;
int8_t
status
;
}
t
mqConnectRsp
;
}
T
mqConnectRsp
;
typedef
struct
t
mqDisconnectReq
{
t
mqMsgHead
head
;
}
tmqDiscon
nectReq
;
typedef
struct
T
mqDisconnectReq
{
T
mqMsgHead
head
;
}
TmqDiscco
nectReq
;
typedef
struct
t
mqDisconnectRsp
{
t
mqMsgHead
head
;
typedef
struct
T
mqDisconnectRsp
{
T
mqMsgHead
head
;
int8_t
status
;
}
tmqDi
connectRsp
;
}
TmqDis
connectRsp
;
typedef
struct
t
mqConsumeReq
{
t
mqMsgHead
head
;
t
mqAcks
acks
;
}
t
mqConsumeReq
;
typedef
struct
T
mqConsumeReq
{
T
mqMsgHead
head
;
T
mqAcks
acks
;
}
T
mqConsumeReq
;
typedef
struct
t
mqMsgContent
{
typedef
struct
T
mqMsgContent
{
int64_t
topicId
;
int64_t
msgLen
;
char
msg
[];
}
t
mqMsgContent
;
}
T
mqMsgContent
;
typedef
struct
t
mqConsumeRsp
{
t
mqMsgHead
head
;
typedef
struct
T
mqConsumeRsp
{
T
mqMsgHead
head
;
int64_t
bodySize
;
t
mqMsgContent
msgs
[];
}
t
mqConsumeRsp
;
T
mqMsgContent
msgs
[];
}
T
mqConsumeRsp
;
typedef
struct
tmqMnode
SubscribeReq
{
t
mqMsgHead
head
;
int
64_t
topicLen
;
char
topic
[];
}
t
mqSubscribeReq
;
typedef
struct
Tmq
SubscribeReq
{
T
mqMsgHead
head
;
int
32_t
topicNum
;
int64_t
topic
[];
}
T
mqSubscribeReq
;
typedef
struct
tmq
Mnode
SubscribeRsp
{
t
mqMsgHead
head
;
typedef
struct
tmqSubscribeRsp
{
T
mqMsgHead
head
;
int64_t
vgId
;
char
ep
[];
//TSDB_EP_LEN
}
t
mqSubscribeRsp
;
char
ep
[
TSDB_EP_LEN
];
//TSDB_EP_LEN
}
T
mqSubscribeRsp
;
typedef
struct
t
mqHeartbeatReq
{
typedef
struct
T
mqHeartbeatReq
{
}
t
mqHeartbeatReq
;
}
T
mqHeartbeatReq
;
typedef
struct
t
mqHeartbeatRsp
{
typedef
struct
T
mqHeartbeatRsp
{
}
t
mqHeartbeatRsp
;
}
T
mqHeartbeatRsp
;
typedef
struct
tqTopicVhandle
{
//name
//
typedef
struct
TqTopicVhandle
{
int64_t
topicId
;
//executor for filter
//
void
*
filterExec
;
//callback for mnode
//
}
tqTopicVhandle
;
//trigger when vnode list associated topic change
void
*
(
*
mCallback
)(
void
*
,
void
*
);
}
TqTopicVhandle
;
typedef
struct
STQ
{
//the collection of group handle
//the handle of kvstore
}
STQ
;
#define TQ_BUFFER_SIZE 8
//TODO: define a serializer and deserializer
typedef
struct
t
qBufferItem
{
typedef
struct
T
qBufferItem
{
int64_t
offset
;
//executors are identical but not concurrent
//so it must be a copy in each item
void
*
executor
;
int64_t
size
;
void
*
content
;
}
t
qBufferItem
;
}
T
qBufferItem
;
typedef
struct
t
qBufferHandle
{
typedef
struct
T
qBufferHandle
{
//char* topic; //c style, end with '\0'
//int64_t cgId;
//void* ahandle;
...
...
@@ -131,32 +132,32 @@ typedef struct tqBufferHandle {
int64_t
topicId
;
int32_t
head
;
int32_t
tail
;
t
qBufferItem
buffer
[
TQ_BUFFER_SIZE
];
}
t
qBufferHandle
;
T
qBufferItem
buffer
[
TQ_BUFFER_SIZE
];
}
T
qBufferHandle
;
typedef
struct
t
qListHandle
{
tqBufferHandle
*
bufHandle
;
struct
t
qListHandle
*
next
;
}
t
qListHandle
;
typedef
struct
T
qListHandle
{
TqBufferHandle
bufHandle
;
struct
T
qListHandle
*
next
;
}
T
qListHandle
;
typedef
struct
t
qGroupHandle
{
typedef
struct
T
qGroupHandle
{
int64_t
cId
;
int64_t
cgId
;
void
*
ahandle
;
int32_t
topicNum
;
t
qListHandle
*
head
;
}
t
qGroupHandle
;
T
qListHandle
*
head
;
}
T
qGroupHandle
;
typedef
struct
t
qQueryExec
{
typedef
struct
T
qQueryExec
{
void
*
src
;
t
qBufferItem
*
dest
;
T
qBufferItem
*
dest
;
void
*
executor
;
}
t
qQueryExec
;
}
T
qQueryExec
;
typedef
struct
t
qQueryMsg
{
t
qQueryExec
*
exec
;
struct
t
qQueryMsg
*
next
;
}
t
qQueryMsg
;
typedef
struct
T
qQueryMsg
{
T
qQueryExec
*
exec
;
struct
T
qQueryMsg
*
next
;
}
T
qQueryMsg
;
//init in each vnode
STQ
*
tqInit
(
void
*
ref_func
(
void
*
),
void
*
unref_func
(
void
*
));
...
...
@@ -166,32 +167,30 @@ void tqCleanUp(STQ*);
int
tqPushMsg
(
STQ
*
,
void
*
msg
,
int64_t
version
);
int
tqCommit
(
STQ
*
);
int
tqConsume
(
STQ
*
,
t
mqConsumeReq
*
);
int
tqConsume
(
STQ
*
,
T
mqConsumeReq
*
);
t
qGroupHandle
*
tqGetGroupHandle
(
STQ
*
,
int64_t
cId
);
T
qGroupHandle
*
tqGetGroupHandle
(
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
(
t
qGroupHandle
*
);
int
tqMoveOffsetToNext
(
T
qGroupHandle
*
);
int
tqResetOffset
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
int64_t
offset
);
int
tqRegisterContext
(
tqGroupHandle
*
,
void
*
);
int
tqLaunchQuery
(
tqGroupHandle
*
);
int
tqSendLaunchQuery
(
STQ
*
,
int64_t
topicId
,
int64_t
cgId
,
void
*
query
);
int
tqSerializeGroupHandle
(
tqGroupHandle
*
gHandle
,
void
**
ppBytes
,
int32_t
offset
);
int
tqSerializeListHandle
(
tqListHandle
*
listHandle
,
void
**
ppBytes
,
int32_t
offset
);
int
tqSerializeBufHandle
(
tqBufferHandle
*
bufHandle
,
void
**
ppBytes
,
int32_t
offset
);
int
tqSerializeBufItem
(
tqBufferItem
*
bufItem
,
void
**
ppBytes
,
int32_t
offset
);
int
tqDeserializeGroupHandle
(
const
void
*
pBytes
,
tqGroupHandle
**
pGhandle
);
int
tqDeserializeListHandle
(
const
void
*
pBytes
,
tqListHandle
**
pListHandle
);
int
tqDeserializeBufHandle
(
const
void
*
pBytes
,
tqBufferHandle
**
pBufHandle
);
int
tqDeserializeBufItem
(
const
void
*
pBytes
,
tqBufferItem
**
pBufItem
);
int
tqGetGHandleSSize
(
const
tqGroupHandle
*
gHandle
);
int
tqListHandleSSize
(
const
tqListHandle
*
listHandle
);
int
tqBufHandleSSize
(
const
tqBufferHandle
*
bufHandle
);
int
tqBufItemSSize
(
const
tqBufferItem
*
bufItem
);
int
tqRegisterContext
(
TqGroupHandle
*
,
void
*
ahandle
);
int
tqLaunchQuery
(
TqGroupHandle
*
);
int
tqSendLaunchQuery
(
TqGroupHandle
*
);
int
tqSerializeGroupHandle
(
TqGroupHandle
*
gHandle
,
void
**
ppBytes
);
void
*
tqSerializeListHandle
(
TqListHandle
*
listHandle
,
void
*
ptr
);
void
*
tqSerializeBufHandle
(
TqBufferHandle
*
bufHandle
,
void
*
ptr
);
void
*
tqSerializeBufItem
(
TqBufferItem
*
bufItem
,
void
*
ptr
);
const
void
*
tqDeserializeGroupHandle
(
const
void
*
pBytes
,
TqGroupHandle
*
ghandle
);
const
void
*
tqDeserializeBufHandle
(
const
void
*
pBytes
,
TqBufferHandle
*
bufHandle
);
const
void
*
tqDeserializeBufItem
(
const
void
*
pBytes
,
TqBufferItem
*
bufItem
);
int
tqGetGHandleSSize
(
const
TqGroupHandle
*
gHandle
);
int
tqBufHandleSSize
();
int
tqBufItemSSize
();
#ifdef __cplusplus
}
...
...
source/libs/sync/src/sync.c
浏览文件 @
a0d8b7df
...
...
@@ -15,5 +15,12 @@
#include "sync.h"
int32_t
syncInit
()
{
return
0
;}
void
syncCleanUp
()
{}
\ No newline at end of file
int32_t
syncInit
()
{
return
0
;
}
void
syncCleanUp
()
{}
SSyncNode
*
syncStart
(
const
SSyncInfo
*
pInfo
)
{
return
NULL
;
}
void
syncStop
(
const
SSyncNode
*
pNode
)
{}
void
syncReconfig
(
const
SSyncNode
*
pNode
,
const
SSyncCluster
*
pCfg
)
{}
\ No newline at end of file
source/libs/wal/CMakeLists.txt
浏览文件 @
a0d8b7df
...
...
@@ -4,9 +4,9 @@ target_include_directories(
wal
PUBLIC
"
${
CMAKE_SOURCE_DIR
}
/include/libs/wal"
PRIVATE
"
${
CMAKE_CURRENT_SOURCE_DIR
}
/inc"
PRIVATE
"
${
CMAKE_SOURCE_DIR
}
/include/os"
)
target_link_libraries
(
os
wal
PUBLIC os
)
source/libs/wal/src/wal.c
浏览文件 @
a0d8b7df
...
...
@@ -19,6 +19,18 @@ int32_t walInit() { return 0; }
void
walCleanUp
()
{}
twalh
walOpen
(
char
*
path
,
SWalCfg
*
pCfg
)
{
return
NULL
;
}
SWal
*
walOpen
(
char
*
path
,
SWalCfg
*
pCfg
)
{
return
NULL
;
}
int32_t
walAlter
(
twalh
pWal
,
SWalCfg
*
pCfg
)
{
return
0
;
}
\ No newline at end of file
int32_t
walAlter
(
SWal
*
pWal
,
SWalCfg
*
pCfg
)
{
return
0
;
}
void
walClose
(
SWal
*
pWal
)
{}
void
walFsync
(
SWal
*
pWal
,
bool
force
)
{}
int64_t
walWrite
(
SWal
*
pWal
,
int64_t
index
,
void
*
body
,
int32_t
bodyLen
)
{}
int32_t
walCommit
(
SWal
*
pWal
,
int64_t
ver
)
{
return
0
;
}
int32_t
walRollback
(
SWal
*
pWal
,
int64_t
ver
)
{
return
0
;
}
int32_t
walPrune
(
SWal
*
pWal
,
int64_t
ver
)
{
return
0
;
}
\ No newline at end of file
source/server/mnode/inc/mnodeInt.h
浏览文件 @
a0d8b7df
...
...
@@ -24,7 +24,7 @@ extern "C" {
tmr_h
mnodeGetTimer
();
int32_t
mnodeGetDnodeId
();
char
*
mnodeGetClusterId
();
int64_t
mnodeGetClusterId
();
EMnStatus
mnodeGetStatus
();
void
mnodeSendMsgToDnode
(
struct
SRpcEpSet
*
epSet
,
struct
SRpcMsg
*
rpcMsg
);
...
...
source/server/mnode/src/mnodeTelem.c
浏览文件 @
a0d8b7df
...
...
@@ -202,12 +202,13 @@ static void mnodeSendTelemetryReport() {
return
;
}
char
clusterId
[
TSDB_CLUSTER_ID_LEN
]
=
{
0
};
mnodeGetClusterId
(
clusterId
);
int64_t
clusterId
=
mnodeGetClusterId
();
char
clusterIdStr
[
20
]
=
{
0
};
snprintf
(
clusterIdStr
,
sizeof
(
clusterIdStr
),
"%"
PRId64
,
clusterId
);
SBufferWriter
bw
=
tbufInitWriter
(
NULL
,
false
);
mnodeBeginObject
(
&
bw
);
mnodeAddStringField
(
&
bw
,
"instanceId"
,
clusterId
);
mnodeAddStringField
(
&
bw
,
"instanceId"
,
clusterId
Str
);
mnodeAddIntField
(
&
bw
,
"reportVersion"
,
1
);
mnodeAddOsInfo
(
&
bw
);
mnodeAddCpuInfo
(
&
bw
);
...
...
source/server/mnode/src/mondeInt.c
浏览文件 @
a0d8b7df
...
...
@@ -39,7 +39,7 @@
static
struct
{
int32_t
state
;
int32_t
dnodeId
;
char
clusterId
[
TSDB_CLUSTER_ID_LEN
]
;
int64_t
clusterId
;
tmr_h
timer
;
SMnodeFp
fp
;
SSteps
*
steps1
;
...
...
@@ -50,7 +50,7 @@ tmr_h mnodeGetTimer() { return tsMint.timer; }
int32_t
mnodeGetDnodeId
()
{
return
tsMint
.
dnodeId
;
}
char
*
mnodeGetClusterId
()
{
return
tsMint
.
clusterId
;
}
int64_t
mnodeGetClusterId
()
{
return
tsMint
.
clusterId
;
}
EMnStatus
mnodeGetStatus
()
{
return
tsMint
.
state
;
}
...
...
@@ -71,12 +71,14 @@ int32_t mnodeGetStatistics(SMnodeStat *stat) { return 0; }
static
int32_t
mnodeSetPara
(
SMnodePara
para
)
{
tsMint
.
fp
=
para
.
fp
;
tsMint
.
dnodeId
=
para
.
dnodeId
;
strncpy
(
tsMint
.
clusterId
,
para
.
clusterId
,
TSDB_CLUSTER_ID_LEN
)
;
tsMint
.
clusterId
=
para
.
clusterId
;
if
(
tsMint
.
fp
.
SendMsgToDnode
==
NULL
)
return
-
1
;
if
(
tsMint
.
fp
.
SendMsgToMnode
==
NULL
)
return
-
1
;
if
(
tsMint
.
fp
.
SendRedirectMsg
==
NULL
)
return
-
1
;
if
(
tsMint
.
fp
.
GetDnodeEp
==
NULL
)
return
-
1
;
if
(
tsMint
.
dnodeId
<
0
)
return
-
1
;
if
(
tsMint
.
clusterId
<
0
)
return
-
1
;
return
0
;
}
...
...
@@ -141,7 +143,7 @@ static void mnodeCleanupStep2() { taosStepCleanup(tsMint.steps2); }
static
bool
mnodeNeedDeploy
()
{
if
(
tsMint
.
dnodeId
>
0
)
return
false
;
if
(
tsMint
.
clusterId
[
0
]
!=
0
)
return
false
;
if
(
tsMint
.
clusterId
>
0
)
return
false
;
if
(
strcmp
(
tsFirst
,
tsLocalEp
)
!=
0
)
return
false
;
return
true
;
}
...
...
@@ -154,7 +156,7 @@ int32_t mnodeDeploy() {
tsMint
.
state
=
MN_STATUS_INIT
;
}
if
(
tsMint
.
dnodeId
<=
0
||
tsMint
.
clusterId
[
0
]
=
=
0
)
{
if
(
tsMint
.
dnodeId
<=
0
||
tsMint
.
clusterId
<
=
0
)
{
mError
(
"failed to deploy mnode since cluster not ready"
);
return
TSDB_CODE_MND_NOT_READY
;
}
...
...
source/server/vnode/inc/vnodeFile.h
浏览文件 @
a0d8b7df
...
...
@@ -23,8 +23,8 @@ extern "C" {
int32_t
vnodeReadCfg
(
int32_t
vgId
,
SVnodeCfg
*
pCfg
);
int32_t
vnodeWriteCfg
(
int32_t
vgId
,
SVnodeCfg
*
pCfg
);
int32_t
vnodeRead
Term
(
int32_t
vgId
,
SSyncServerState
*
pState
);
int32_t
vnode
WriteTerm
(
int32_t
vgid
,
SSyncServerState
*
pState
);
int32_t
vnodeRead
State
(
int32_t
vgId
,
SSyncServerState
*
pState
);
int32_t
vnode
SaveState
(
int32_t
vgid
,
SSyncServerState
*
pState
);
#ifdef __cplusplus
}
...
...
source/server/vnode/inc/vnodeInt.h
浏览文件 @
a0d8b7df
...
...
@@ -62,19 +62,14 @@ typedef struct STsdbCfg {
typedef
struct
SMetaCfg
{
}
SMetaCfg
;
typedef
struct
SSyncCluster
{
int8_t
replica
;
int8_t
quorum
;
SNodeInfo
nodes
[
TSDB_MAX_REPLICA
];
}
SSyncCfg
;
typedef
struct
SVnodeCfg
{
char
db
[
TSDB_ACCT_ID_LEN
+
TSDB_DB_NAME_LEN
];
int8_t
dropped
;
SWalCfg
wal
;
STsdbCfg
tsdb
;
SMetaCfg
meta
;
SSyncCfg
sync
;
char
db
[
TSDB_ACCT_ID_LEN
+
TSDB_DB_NAME_LEN
];
int8_t
dropped
;
int8_t
quorum
;
SWalCfg
wal
;
STsdbCfg
tsdb
;
SMetaCfg
meta
;
SSyncCluster
sync
;
}
SVnodeCfg
;
typedef
struct
{
...
...
@@ -84,9 +79,9 @@ typedef struct {
SMeta
*
pMeta
;
STsdb
*
pTsdb
;
STQ
*
pTQ
;
twalh
pWal
;
SWal
*
pWal
;
void
*
pQuery
;
S
yncNodeId
syncNode
;
S
SyncNode
*
pSync
;
taos_queue
pWriteQ
;
// write queue
taos_queue
pQueryQ
;
// read query queue
taos_queue
pFetchQ
;
// read fetch/cancel queue
...
...
source/server/vnode/meta/src/metaMain.c
浏览文件 @
a0d8b7df
...
...
@@ -64,6 +64,7 @@ SMeta *metaOpen(SMetaOpts *pMetaOpts) {
// TODO: need to figure out how to persist the START UID
tableUidGeneratorInit
(
&
(
pMeta
->
uidGenerator
),
IVLD_TB_UID
);
return
pMeta
;
}
void
metaClose
(
SMeta
*
pMeta
)
{
...
...
source/server/vnode/src/vnodeFile.c
浏览文件 @
a0d8b7df
...
...
@@ -30,149 +30,156 @@ int32_t vnodeReadCfg(int32_t vgId, SVnodeCfg *pCfg) {
fp
=
fopen
(
file
,
"r"
);
if
(
!
fp
)
{
vError
(
"vgId:%d, failed to open vnode cfg file:%s to read
, error:
%s"
,
vgId
,
file
,
strerror
(
errno
));
vError
(
"vgId:%d, failed to open vnode cfg file:%s to read
since
%s"
,
vgId
,
file
,
strerror
(
errno
));
ret
=
TAOS_SYSTEM_ERROR
(
errno
);
goto
PARSE_VCFG_ERROR
;
}
len
=
(
int32_t
)
fread
(
content
,
1
,
maxLen
,
fp
);
if
(
len
<=
0
)
{
vError
(
"vgId:%d, failed to read %s
,
content is null"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
content is null"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
content
[
len
]
=
0
;
root
=
cJSON_Parse
(
content
);
if
(
root
==
NULL
)
{
vError
(
"vgId:%d, failed to read %s
,
invalid json format"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
invalid json format"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
cJSON
*
db
=
cJSON_GetObjectItem
(
root
,
"db"
);
if
(
!
db
||
db
->
type
!=
cJSON_String
||
db
->
valuestring
==
NULL
)
{
vError
(
"vgId:%d, failed to read %s
,
db not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
db not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
tstrncpy
(
pCfg
->
db
,
db
->
valuestring
,
sizeof
(
pCfg
->
db
));
cJSON
*
dropped
=
cJSON_GetObjectItem
(
root
,
"dropped"
);
if
(
!
dropped
||
dropped
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
dropped not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
dropped not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
dropped
=
(
int32_t
)
dropped
->
valueint
;
cJSON
*
quorum
=
cJSON_GetObjectItem
(
root
,
"quorum"
);
if
(
!
quorum
||
quorum
->
type
!=
cJSON_Number
)
{
vError
(
"vgId: %d, failed to read %s, quorum not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
quorum
=
(
int8_t
)
quorum
->
valueint
;
cJSON
*
cacheBlockSize
=
cJSON_GetObjectItem
(
root
,
"cacheBlockSize"
);
if
(
!
cacheBlockSize
||
cacheBlockSize
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
cacheBlockSize not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
cacheBlockSize not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
cacheBlockSize
=
(
int32_t
)
cacheBlockSize
->
valueint
;
cJSON
*
totalBlocks
=
cJSON_GetObjectItem
(
root
,
"totalBlocks"
);
if
(
!
totalBlocks
||
totalBlocks
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
totalBlocks not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
totalBlocks not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
totalBlocks
=
(
int32_t
)
totalBlocks
->
valueint
;
cJSON
*
daysPerFile
=
cJSON_GetObjectItem
(
root
,
"daysPerFile"
);
if
(
!
daysPerFile
||
daysPerFile
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
daysPerFile not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
daysPerFile not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
daysPerFile
=
(
int32_t
)
daysPerFile
->
valueint
;
cJSON
*
daysToKeep0
=
cJSON_GetObjectItem
(
root
,
"daysToKeep0"
);
if
(
!
daysToKeep0
||
daysToKeep0
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
daysToKeep0 not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
daysToKeep0 not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
daysToKeep0
=
(
int32_t
)
daysToKeep0
->
valueint
;
cJSON
*
daysToKeep1
=
cJSON_GetObjectItem
(
root
,
"daysToKeep1"
);
if
(
!
daysToKeep1
||
daysToKeep1
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
daysToKeep1 not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
daysToKeep1 not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
daysToKeep1
=
(
int32_t
)
daysToKeep1
->
valueint
;
cJSON
*
daysToKeep2
=
cJSON_GetObjectItem
(
root
,
"daysToKeep2"
);
if
(
!
daysToKeep2
||
daysToKeep2
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
daysToKeep2 not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
daysToKeep2 not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
daysToKeep2
=
(
int32_t
)
daysToKeep2
->
valueint
;
cJSON
*
minRowsPerFileBlock
=
cJSON_GetObjectItem
(
root
,
"minRowsPerFileBlock"
);
if
(
!
minRowsPerFileBlock
||
minRowsPerFileBlock
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
minRowsPerFileBlock not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
minRowsPerFileBlock not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
minRowsPerFileBlock
=
(
int32_t
)
minRowsPerFileBlock
->
valueint
;
cJSON
*
maxRowsPerFileBlock
=
cJSON_GetObjectItem
(
root
,
"maxRowsPerFileBlock"
);
if
(
!
maxRowsPerFileBlock
||
maxRowsPerFileBlock
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
maxRowsPerFileBlock not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
maxRowsPerFileBlock not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
maxRowsPerFileBlock
=
(
int32_t
)
maxRowsPerFileBlock
->
valueint
;
cJSON
*
precision
=
cJSON_GetObjectItem
(
root
,
"precision"
);
if
(
!
precision
||
precision
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
precision not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
precision not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
precision
=
(
int8_t
)
precision
->
valueint
;
cJSON
*
compression
=
cJSON_GetObjectItem
(
root
,
"compression"
);
if
(
!
compression
||
compression
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
compression not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
compression not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
compression
=
(
int8_t
)
compression
->
valueint
;
cJSON
*
update
=
cJSON_GetObjectItem
(
root
,
"update"
);
if
(
!
update
||
update
->
type
!=
cJSON_Number
)
{
vError
(
"vgId: %d, failed to read %s
,
update not found"
,
vgId
,
file
);
vError
(
"vgId: %d, failed to read %s
since
update not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
update
=
(
int8_t
)
update
->
valueint
;
cJSON
*
cacheLastRow
=
cJSON_GetObjectItem
(
root
,
"cacheLastRow"
);
if
(
!
cacheLastRow
||
cacheLastRow
->
type
!=
cJSON_Number
)
{
vError
(
"vgId: %d, failed to read %s
,
cacheLastRow not found"
,
vgId
,
file
);
vError
(
"vgId: %d, failed to read %s
since
cacheLastRow not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
tsdb
.
cacheLastRow
=
(
int8_t
)
cacheLastRow
->
valueint
;
cJSON
*
walLevel
=
cJSON_GetObjectItem
(
root
,
"walLevel"
);
if
(
!
walLevel
||
walLevel
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
walLevel not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
walLevel not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
wal
.
walLevel
=
(
int8_t
)
walLevel
->
valueint
;
cJSON
*
fsyncPeriod
=
cJSON_GetObjectItem
(
root
,
"fsyncPeriod"
);
if
(
!
walLevel
||
walLevel
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
,
fsyncPeriod not found"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
fsyncPeriod not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
wal
.
fsyncPeriod
=
(
int32_t
)
fsyncPeriod
->
valueint
;
cJSON
*
replica
=
cJSON_GetObjectItem
(
root
,
"replica
"
);
if
(
!
replica
||
replica
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
, replica
not found"
,
vgId
,
file
);
cJSON
*
selfIndex
=
cJSON_GetObjectItem
(
root
,
"selfIndex
"
);
if
(
!
selfIndex
||
selfIndex
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
since selfIndex
not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
sync
.
replica
=
(
int8_t
)
replica
->
valueint
;
pCfg
->
sync
.
selfIndex
=
selfIndex
->
valueint
;
cJSON
*
quorum
=
cJSON_GetObjectItem
(
root
,
"quorum
"
);
if
(
!
quorum
||
quorum
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:
%d, failed to read %s, quorum
not found"
,
vgId
,
file
);
cJSON
*
replica
=
cJSON_GetObjectItem
(
root
,
"replica
"
);
if
(
!
replica
||
replica
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:
%d, failed to read %s since replica
not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
pCfg
->
sync
.
quorum
=
(
int8_t
)
quorum
->
valueint
;
pCfg
->
sync
.
replica
=
replica
->
valueint
;
cJSON
*
nodes
=
cJSON_GetObjectItem
(
root
,
"nodes"
);
if
(
!
nodes
||
nodes
->
type
!=
cJSON_Array
)
{
...
...
@@ -182,28 +189,35 @@ int32_t vnodeReadCfg(int32_t vgId, SVnodeCfg *pCfg) {
int
size
=
cJSON_GetArraySize
(
nodes
);
if
(
size
!=
pCfg
->
sync
.
replica
)
{
vError
(
"vgId:%d, failed to read %s
,
nodes size not matched"
,
vgId
,
file
);
vError
(
"vgId:%d, failed to read %s
since
nodes size not matched"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
for
(
int
i
=
0
;
i
<
size
;
++
i
)
{
cJSON
*
nodeInfo
=
cJSON_GetArrayItem
(
nodes
,
i
);
if
(
nodeInfo
==
NULL
)
continue
;
SNodeInfo
*
node
=
&
pCfg
->
sync
.
nodes
[
i
];
SNodeInfo
*
node
=
&
pCfg
->
sync
.
nodeInfo
[
i
];
cJSON
*
nodeId
=
cJSON_GetObjectItem
(
nodeInfo
,
"id"
);
if
(
!
nodeId
||
nodeId
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s since nodeId not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
node
->
nodeId
=
nodeId
->
valueint
;
cJSON
*
p
ort
=
cJSON_GetObjectItem
(
nodeInfo
,
"port"
);
if
(
!
port
||
p
ort
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
, p
ort not found"
,
vgId
,
file
);
cJSON
*
nodeP
ort
=
cJSON_GetObjectItem
(
nodeInfo
,
"port"
);
if
(
!
nodePort
||
nodeP
ort
->
type
!=
cJSON_Number
)
{
vError
(
"vgId:%d, failed to read %s
sincenodeP
ort not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
node
->
nodePort
=
(
uint16_t
)
p
ort
->
valueint
;
node
->
nodePort
=
(
uint16_t
)
nodeP
ort
->
valueint
;
cJSON
*
f
qdn
=
cJSON_GetObjectItem
(
nodeInfo
,
"fqdn"
);
if
(
!
fqdn
||
fqdn
->
type
!=
cJSON_String
||
f
qdn
->
valuestring
==
NULL
)
{
vError
(
"vgId:%d, failed to read %s
, f
qdn not found"
,
vgId
,
file
);
cJSON
*
nodeF
qdn
=
cJSON_GetObjectItem
(
nodeInfo
,
"fqdn"
);
if
(
!
nodeFqdn
||
nodeFqdn
->
type
!=
cJSON_String
||
nodeF
qdn
->
valuestring
==
NULL
)
{
vError
(
"vgId:%d, failed to read %s
since nodeF
qdn not found"
,
vgId
,
file
);
goto
PARSE_VCFG_ERROR
;
}
tstrncpy
(
node
->
nodeFqdn
,
f
qdn
->
valuestring
,
TSDB_FQDN_LEN
);
tstrncpy
(
node
->
nodeFqdn
,
nodeF
qdn
->
valuestring
,
TSDB_FQDN_LEN
);
}
ret
=
TSDB_CODE_SUCCESS
;
...
...
@@ -238,6 +252,7 @@ int32_t vnodeWriteCfg(int32_t vgId, SVnodeCfg *pCfg) {
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
vgId
\"
: %d,
\n
"
,
vgId
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
db
\"
:
\"
%s
\"
,
\n
"
,
pCfg
->
db
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
dropped
\"
: %d,
\n
"
,
pCfg
->
dropped
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
quorum
\"
: %d,
\n
"
,
pCfg
->
quorum
);
// tsdb
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
cacheBlockSize
\"
: %d,
\n
"
,
pCfg
->
tsdb
.
cacheBlockSize
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
totalBlocks
\"
: %d,
\n
"
,
pCfg
->
tsdb
.
totalBlocks
);
...
...
@@ -255,11 +270,12 @@ int32_t vnodeWriteCfg(int32_t vgId, SVnodeCfg *pCfg) {
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
walLevel
\"
: %d,
\n
"
,
pCfg
->
wal
.
walLevel
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
fsyncPeriod
\"
: %d,
\n
"
,
pCfg
->
wal
.
fsyncPeriod
);
// sync
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
quorum
\"
: %d,
\n
"
,
pCfg
->
sync
.
quorum
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
replica
\"
: %d,
\n
"
,
pCfg
->
sync
.
replica
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
selfIndex
\"
: %d,
\n
"
,
pCfg
->
sync
.
selfIndex
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
nodes
\"
: [{
\n
"
);
for
(
int32_t
i
=
0
;
i
<
pCfg
->
sync
.
replica
;
i
++
)
{
SNodeInfo
*
node
=
&
pCfg
->
sync
.
nodes
[
i
];
SNodeInfo
*
node
=
&
pCfg
->
sync
.
nodeInfo
[
i
];
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
id
\"
: %d,
\n
"
,
node
->
nodeId
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
port
\"
: %u,
\n
"
,
node
->
nodePort
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
fqdn
\"
:
\"
%s
\"\n
"
,
node
->
nodeFqdn
);
if
(
i
<
pCfg
->
sync
.
replica
-
1
)
{
...
...
@@ -280,7 +296,7 @@ int32_t vnodeWriteCfg(int32_t vgId, SVnodeCfg *pCfg) {
return
TSDB_CODE_SUCCESS
;
}
int32_t
vnodeRead
Term
(
int32_t
vgId
,
SSyncServerState
*
pState
)
{
int32_t
vnodeRead
State
(
int32_t
vgId
,
SSyncServerState
*
pState
)
{
int32_t
ret
=
TSDB_CODE_VND_APP_ERROR
;
int32_t
len
=
0
;
int32_t
maxLen
=
100
;
...
...
@@ -289,7 +305,7 @@ int32_t vnodeReadTerm(int32_t vgId, SSyncServerState *pState) {
FILE
*
fp
=
NULL
;
char
file
[
PATH_MAX
+
30
]
=
{
0
};
sprintf
(
file
,
"%s/vnode%d/
term
.json"
,
tsVnodeDir
,
vgId
);
sprintf
(
file
,
"%s/vnode%d/
state
.json"
,
tsVnodeDir
,
vgId
);
len
=
(
int32_t
)
fread
(
content
,
1
,
maxLen
,
fp
);
if
(
len
<=
0
)
{
...
...
@@ -304,20 +320,20 @@ int32_t vnodeReadTerm(int32_t vgId, SSyncServerState *pState) {
}
cJSON
*
term
=
cJSON_GetObjectItem
(
root
,
"term"
);
if
(
!
term
||
term
->
type
!=
cJSON_
Number
)
{
if
(
!
term
||
term
->
type
!=
cJSON_
String
)
{
vError
(
"vgId:%d, failed to read %s since term not found"
,
vgId
,
file
);
goto
PARSE_TERM_ERROR
;
}
pState
->
term
=
(
uint64_t
)
term
->
valueint
;
pState
->
term
=
atoll
(
term
->
valuestring
)
;
cJSON
*
voteFor
=
cJSON_GetObjectItem
(
root
,
"voteFor"
);
if
(
!
voteFor
||
voteFor
->
type
!=
cJSON_
Number
)
{
if
(
!
voteFor
||
voteFor
->
type
!=
cJSON_
String
)
{
vError
(
"vgId:%d, failed to read %s since voteFor not found"
,
vgId
,
file
);
goto
PARSE_TERM_ERROR
;
}
pState
->
voteFor
=
(
int64_t
)
voteFor
->
valueint
;
pState
->
voteFor
=
atoi
(
voteFor
->
valuestring
)
;
vInfo
(
"vgId:%d, read %s success, voteFor:%
"
PRIu64
"
, term:%"
PRIu64
,
vgId
,
file
,
pState
->
voteFor
,
pState
->
term
);
vInfo
(
"vgId:%d, read %s success, voteFor:%
d
, term:%"
PRIu64
,
vgId
,
file
,
pState
->
voteFor
,
pState
->
term
);
PARSE_TERM_ERROR:
if
(
content
!=
NULL
)
free
(
content
);
...
...
@@ -327,9 +343,9 @@ PARSE_TERM_ERROR:
return
ret
;
}
int32_t
vnode
WriteTerm
(
int32_t
vgId
,
SSyncServerState
*
pState
)
{
int32_t
vnode
SaveState
(
int32_t
vgId
,
SSyncServerState
*
pState
)
{
char
file
[
PATH_MAX
+
30
]
=
{
0
};
sprintf
(
file
,
"%s/vnode%d/
term
.json"
,
tsVnodeDir
,
vgId
);
sprintf
(
file
,
"%s/vnode%d/
state
.json"
,
tsVnodeDir
,
vgId
);
FILE
*
fp
=
fopen
(
file
,
"w"
);
if
(
!
fp
)
{
...
...
@@ -342,8 +358,8 @@ int32_t vnodeWriteTerm(int32_t vgId, SSyncServerState *pState) {
char
*
content
=
calloc
(
1
,
maxLen
+
1
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"{
\n
"
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
term
\"
:
%"
PRIu64
"
\n
"
,
pState
->
term
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
voteFor
\"
:
%"
PRIu64
"
\n
"
,
pState
->
voteFor
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
term
\"
:
\"
%"
PRIu64
"
\"
,
\n
"
,
pState
->
term
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"
\"
voteFor
\"
:
\"
%d
\
"\n
"
,
pState
->
voteFor
);
len
+=
snprintf
(
content
+
len
,
maxLen
-
len
,
"}
\n
"
);
fwrite
(
content
,
1
,
len
,
fp
);
...
...
@@ -351,6 +367,6 @@ int32_t vnodeWriteTerm(int32_t vgId, SSyncServerState *pState) {
fclose
(
fp
);
free
(
content
);
vInfo
(
"vgId:%d, write %s success, voteFor:%
"
PRIu64
"
, term:%"
PRIu64
,
vgId
,
file
,
pState
->
voteFor
,
pState
->
term
);
vInfo
(
"vgId:%d, write %s success, voteFor:%
d
, term:%"
PRIu64
,
vgId
,
file
,
pState
->
voteFor
,
pState
->
term
);
return
TSDB_CODE_SUCCESS
;
}
\ No newline at end of file
source/server/vnode/src/vnodeMain.c
浏览文件 @
a0d8b7df
...
...
@@ -108,6 +108,11 @@ static void vnodeDestroyVnode(SVnode *pVnode) {
int32_t
code
=
0
;
int32_t
vgId
=
pVnode
->
vgId
;
if
(
pVnode
->
pSync
!=
NULL
)
{
syncStop
(
pVnode
->
pSync
);
pVnode
->
pSync
=
NULL
;
}
if
(
pVnode
->
pQuery
)
{
// todo
}
...
...
@@ -125,7 +130,8 @@ static void vnodeDestroyVnode(SVnode *pVnode) {
}
if
(
pVnode
->
pWal
)
{
// todo
walClose
(
pVnode
->
pWal
);
pVnode
->
pWal
=
NULL
;
}
if
(
pVnode
->
allocator
)
{
...
...
@@ -161,6 +167,56 @@ static void vnodeCleanupVnode(SVnode *pVnode) {
vnodeRelease
(
pVnode
);
}
static
inline
int32_t
vnodeLogWrite
(
struct
SSyncLogStore
*
logStore
,
SyncIndex
index
,
SSyncBuffer
*
pBuf
)
{
SVnode
*
pVnode
=
logStore
->
pData
;
// vnode status can be checked here
return
walWrite
(
pVnode
->
pWal
,
index
,
pBuf
->
data
,
(
int32_t
)
pBuf
->
len
);
}
static
inline
int32_t
vnodeLogCommit
(
struct
SSyncLogStore
*
logStore
,
SyncIndex
index
)
{
SVnode
*
pVnode
=
logStore
->
pData
;
// vnode status can be checked here
return
walCommit
(
pVnode
->
pWal
,
index
);
}
static
inline
int32_t
vnodeLogPrune
(
struct
SSyncLogStore
*
logStore
,
SyncIndex
index
)
{
SVnode
*
pVnode
=
logStore
->
pData
;
// vnode status can be checked here
return
walPrune
(
pVnode
->
pWal
,
index
);
}
static
inline
int32_t
vnodeLogRollback
(
struct
SSyncLogStore
*
logStore
,
SyncIndex
index
)
{
SVnode
*
pVnode
=
logStore
->
pData
;
// vnode status can be checked here
return
walRollback
(
pVnode
->
pWal
,
index
);
}
static
inline
int32_t
vnodeSaveServerState
(
struct
SStateManager
*
stateMng
,
SSyncServerState
*
pState
)
{
SVnode
*
pVnode
=
stateMng
->
pData
;
return
vnodeSaveState
(
pVnode
->
vgId
,
pState
);
}
static
inline
int32_t
vnodeReadServerState
(
struct
SStateManager
*
stateMng
,
SSyncServerState
*
pState
)
{
SVnode
*
pVnode
=
stateMng
->
pData
;
return
vnodeSaveState
(
pVnode
->
vgId
,
pState
);
}
static
inline
int32_t
vnodeApplyLog
(
struct
SSyncFSM
*
fsm
,
SyncIndex
index
,
const
SSyncBuffer
*
buf
,
void
*
pData
)
{
return
0
;
}
static
inline
int32_t
vnodeOnClusterChanged
(
struct
SSyncFSM
*
fsm
,
const
SSyncCluster
*
cluster
,
void
*
pData
)
{
return
0
;
}
static
inline
int32_t
vnodeGetSnapshot
(
struct
SSyncFSM
*
fsm
,
SSyncBuffer
**
ppBuf
,
int32_t
*
objId
,
bool
*
isLast
)
{
return
0
;
}
static
inline
int32_t
vnodeApplySnapshot
(
struct
SSyncFSM
*
fsm
,
SSyncBuffer
*
pBuf
,
int32_t
objId
,
bool
isLast
)
{
return
0
;
}
static
inline
int32_t
vnodeOnRestoreDone
(
struct
SSyncFSM
*
fsm
)
{
return
0
;
}
static
inline
void
vnodeOnRollback
(
struct
SSyncFSM
*
fsm
,
SyncIndex
index
,
const
SSyncBuffer
*
buf
)
{}
static
inline
void
vnodeOnRoleChanged
(
struct
SSyncFSM
*
fsm
,
const
SNodesRole
*
pRole
)
{}
static
int32_t
vnodeOpenVnode
(
int32_t
vgId
)
{
int32_t
code
=
0
;
...
...
@@ -177,6 +233,9 @@ static int32_t vnodeOpenVnode(int32_t vgId) {
pVnode
->
role
=
TAOS_SYNC_ROLE_CANDIDATE
;
pthread_mutex_init
(
&
pVnode
->
statusMutex
,
NULL
);
vDebug
(
"vgId:%d, vnode is opened"
,
pVnode
->
vgId
);
taosHashPut
(
tsVnode
.
hash
,
&
pVnode
->
vgId
,
sizeof
(
int32_t
),
&
pVnode
,
sizeof
(
SVnode
*
));
code
=
vnodeReadCfg
(
vgId
,
&
pVnode
->
cfg
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
vError
(
"vgId:%d, failed to read config file, set cfgVersion to 0"
,
pVnode
->
vgId
);
...
...
@@ -185,7 +244,7 @@ static int32_t vnodeOpenVnode(int32_t vgId) {
return
0
;
}
code
=
vnode
ReadTerm
(
vgId
,
&
pVnode
->
term
);
code
=
vnode
SaveState
(
vgId
,
&
pVnode
->
term
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
vError
(
"vgId:%d, failed to read term file since %s"
,
pVnode
->
vgId
,
tstrerror
(
code
));
pVnode
->
cfg
.
dropped
=
1
;
...
...
@@ -209,8 +268,33 @@ static int32_t vnodeOpenVnode(int32_t vgId) {
return
terrno
;
}
vDebug
(
"vgId:%d, vnode is opened"
,
pVnode
->
vgId
);
taosHashPut
(
tsVnode
.
hash
,
&
pVnode
->
vgId
,
sizeof
(
int32_t
),
&
pVnode
,
sizeof
(
SVnode
*
));
// create sync node
SSyncInfo
syncInfo
=
{
0
};
syncInfo
.
vgId
=
vgId
;
syncInfo
.
snapshotIndex
=
0
;
// todo, from tsdb
memcpy
(
&
syncInfo
.
syncCfg
,
&
pVnode
->
cfg
.
sync
,
sizeof
(
SSyncCluster
));
syncInfo
.
fsm
.
pData
=
pVnode
;
syncInfo
.
fsm
.
applyLog
=
vnodeApplyLog
;
syncInfo
.
fsm
.
onClusterChanged
=
vnodeOnClusterChanged
;
syncInfo
.
fsm
.
getSnapshot
=
vnodeGetSnapshot
;
syncInfo
.
fsm
.
applySnapshot
=
vnodeApplySnapshot
;
syncInfo
.
fsm
.
onRestoreDone
=
vnodeOnRestoreDone
;
syncInfo
.
fsm
.
onRollback
=
vnodeOnRollback
;
syncInfo
.
fsm
.
onRoleChanged
=
vnodeOnRoleChanged
;
syncInfo
.
logStore
.
pData
=
pVnode
;
syncInfo
.
logStore
.
logWrite
=
vnodeLogWrite
;
syncInfo
.
logStore
.
logCommit
=
vnodeLogCommit
;
syncInfo
.
logStore
.
logPrune
=
vnodeLogPrune
;
syncInfo
.
logStore
.
logRollback
=
vnodeLogRollback
;
syncInfo
.
stateManager
.
pData
=
pVnode
;
syncInfo
.
stateManager
.
saveServerState
=
vnodeSaveServerState
;
syncInfo
.
stateManager
.
readServerState
=
vnodeReadServerState
;
pVnode
->
pSync
=
syncStart
(
&
syncInfo
);
if
(
pVnode
->
pSync
==
NULL
)
{
vnodeCleanupVnode
(
pVnode
);
return
terrno
;
}
vnodeSetReadyStatus
(
pVnode
);
return
TSDB_CODE_SUCCESS
;
...
...
@@ -313,7 +397,7 @@ int32_t vnodeAlterVnode(SVnode * pVnode, SVnodeCfg *pCfg) {
}
if
(
syncChanged
)
{
// todo
syncReconfig
(
pVnode
->
pSync
,
&
pVnode
->
cfg
.
sync
);
}
vnodeRelease
(
pVnode
);
...
...
source/server/vnode/src/vnodeMgmt.c
浏览文件 @
a0d8b7df
...
...
@@ -31,6 +31,7 @@ static int32_t vnodeParseCreateVnodeReq(SRpcMsg *rpcMsg, int32_t *vgId, SVnodeCf
*
vgId
=
htonl
(
pCreate
->
vgId
);
pCfg
->
dropped
=
0
;
pCfg
->
quorum
=
pCreate
->
quorum
;
tstrncpy
(
pCfg
->
db
,
pCreate
->
db
,
sizeof
(
pCfg
->
db
));
pCfg
->
tsdb
.
cacheBlockSize
=
htonl
(
pCreate
->
cacheBlockSize
);
...
...
@@ -50,11 +51,11 @@ static int32_t vnodeParseCreateVnodeReq(SRpcMsg *rpcMsg, int32_t *vgId, SVnodeCf
pCfg
->
wal
.
walLevel
=
pCreate
->
walLevel
;
pCfg
->
sync
.
replica
=
pCreate
->
replica
;
pCfg
->
sync
.
quorum
=
pCreate
->
quorum
;
pCfg
->
sync
.
selfIndex
=
pCreate
->
selfIndex
;
for
(
int32_t
j
=
0
;
j
<
pCreate
->
replica
;
++
j
)
{
pCfg
->
sync
.
node
s
[
j
].
nodePort
=
htons
(
pCreate
->
nodes
[
j
].
port
);
tstrncpy
(
pCfg
->
sync
.
node
s
[
j
].
nodeFqdn
,
pCreate
->
nodes
[
j
].
fqdn
,
TSDB_FQDN_LEN
);
pCfg
->
sync
.
node
Info
[
j
].
nodePort
=
htons
(
pCreate
->
nodes
[
j
].
port
);
tstrncpy
(
pCfg
->
sync
.
node
Info
[
j
].
nodeFqdn
,
pCreate
->
nodes
[
j
].
fqdn
,
TSDB_FQDN_LEN
);
}
return
0
;
...
...
source/server/vnode/src/vnodeReadMsg.c
浏览文件 @
a0d8b7df
...
...
@@ -217,8 +217,8 @@ int32_t vnodeProcessQueryMsg(SVnode *pVnode, SReadMsg *pRead) {
int32_t
vnodeProcessConsumeMsg
(
SVnode
*
pVnode
,
SReadMsg
*
pRead
)
{
//parse message and optionally move offset
void
*
pMsg
=
pRead
->
pCont
;
tmqConsumeReq
*
pConsumeMsg
=
(
t
mqConsumeReq
*
)
pMsg
;
t
mqMsgHead
msgHead
=
pConsumeMsg
->
head
;
TmqConsumeReq
*
pConsumeMsg
=
(
T
mqConsumeReq
*
)
pMsg
;
T
mqMsgHead
msgHead
=
pConsumeMsg
->
head
;
//extract head
STQ
*
pTq
=
pVnode
->
pTQ
;
/*tqBufferHandle *pHandle = tqGetHandle(pTq, msgHead.clientId);*/
...
...
source/server/vnode/tq/CMakeLists.txt
浏览文件 @
a0d8b7df
...
...
@@ -3,11 +3,12 @@ add_library(tq ${TQ_SRC})
target_include_directories
(
tq
PUBLIC
"
${
CMAKE_SOURCE_DIR
}
/include/server/vnode/tq"
PUBLIC
"
${
CMAKE_SOURCE_DIR
}
/include/libs/wal"
PRIVATE
"
${
CMAKE_CURRENT_SOURCE_DIR
}
/inc"
PRIVATE
"
${
CMAKE_SOURCE_DIR
}
/include/os"
)
target_link_libraries
(
wal
tq
PUBLIC wal
PUBLIC os
PUBLIC util
)
source/server/vnode/tq/inc/tqCommit.h
0 → 100644
浏览文件 @
a0d8b7df
/*
* 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/>.
*/
source/server/vnode/tq/inc/tqInt.h
浏览文件 @
a0d8b7df
...
...
@@ -18,7 +18,6 @@
#include "tq.h"
#ifdef __cplusplus
extern
"C"
{
#endif
...
...
source/server/vnode/tq/inc/tqMetaStore.h
0 → 100644
浏览文件 @
a0d8b7df
/*
* 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/>.
*/
#ifndef _TQ_META_STORE_H_
#define _TQ_META_STORE_H_
#include "os.h"
#define TQ_INUSE_SIZE 0xFF
#define TQ_PAGE_SIZE 4096
#ifdef __cplusplus
extern
"C"
{
#endif
typedef
struct
TqMetaHandle
{
int64_t
key
;
int64_t
offset
;
void
*
valueInUse
;
void
*
valueInTxn
;
}
TqMetaHandle
;
typedef
struct
TqMetaList
{
TqMetaHandle
handle
;
struct
TqMetaList
*
next
;
struct
TqMetaList
*
inTxnPrev
;
struct
TqMetaList
*
inTxnNext
;
struct
TqMetaList
*
unpersistPrev
;
struct
TqMetaList
*
unpersistNext
;
}
TqMetaList
;
typedef
struct
TqMetaStore
{
TqMetaList
*
inUse
[
TQ_INUSE_SIZE
];
TqMetaList
*
unpersistHead
;
//deserializer
//serializer
//deleter
}
TqMetaStore
;
typedef
struct
TqMetaPageBuf
{
int16_t
offset
;
char
buffer
[
TQ_PAGE_SIZE
];
}
TqMetaPageBuf
;
TqMetaStore
*
TqStoreOpen
(
const
char
*
path
,
void
*
serializer
(
void
*
),
void
*
deserializer
(
void
*
));
int32_t
TqStoreClose
(
TqMetaStore
*
);
int32_t
TqStoreDelete
(
TqMetaStore
*
);
int32_t
TqStoreCommitAll
(
TqMetaStore
*
);
int32_t
TqStorePersist
(
TqMetaStore
*
);
TqMetaHandle
*
TqHandleGetInUse
(
TqMetaStore
*
,
int64_t
key
);
int32_t
TqHandlePutInUse
(
TqMetaStore
*
,
TqMetaHandle
*
handle
);
TqMetaHandle
*
TqHandleGetInTxn
(
TqMetaStore
*
,
int64_t
key
);
int32_t
TqHandlePutInTxn
(
TqMetaStore
*
,
TqMetaHandle
*
handle
);
//delete in-use-handle, make in-txn-handle in use
int32_t
TqHandleCommit
(
TqMetaStore
*
,
int64_t
key
);
//delete in-txn-handle
int32_t
TqHandleAbort
(
TqMetaStore
*
,
int64_t
key
);
//delete in-use-handle
int32_t
TqHandleDel
(
TqMetaStore
*
,
int64_t
key
);
//delete in-use-handle and in-txn-handle
int32_t
TqHandleClear
(
TqMetaStore
*
,
int64_t
key
);
#ifdef __cplusplus
}
#endif
#endif
/* ifndef _TQ_META_STORE_H_ */
source/server/vnode/tq/src/tq.c
浏览文件 @
a0d8b7df
...
...
@@ -22,18 +22,18 @@
//
//handle management message
//
static
int
tqProtoCheck
(
t
mqMsgHead
*
pMsg
)
{
static
int
tqProtoCheck
(
T
mqMsgHead
*
pMsg
)
{
return
pMsg
->
protoVer
==
0
;
}
static
int
tqAckOneTopic
(
tqBufferHandle
*
bhandle
,
tmqOneAck
*
pAck
,
t
qQueryMsg
**
ppQuery
)
{
static
int
tqAckOneTopic
(
TqBufferHandle
*
bhandle
,
TmqOneAck
*
pAck
,
T
qQueryMsg
**
ppQuery
)
{
//clean old item and move forward
int32_t
consumeOffset
=
pAck
->
consumeOffset
;
int
idx
=
consumeOffset
%
TQ_BUFFER_SIZE
;
ASSERT
(
bhandle
->
buffer
[
idx
].
content
&&
bhandle
->
buffer
[
idx
].
executor
);
tfree
(
bhandle
->
buffer
[
idx
].
content
);
if
(
1
/* TODO: need to launch new query */
)
{
tqQueryMsg
*
pNewQuery
=
malloc
(
sizeof
(
t
qQueryMsg
));
TqQueryMsg
*
pNewQuery
=
malloc
(
sizeof
(
T
qQueryMsg
));
if
(
pNewQuery
==
NULL
)
{
//TODO: memory insufficient
return
-
1
;
...
...
@@ -49,19 +49,19 @@ static int tqAckOneTopic(tqBufferHandle *bhandle, tmqOneAck *pAck, tqQueryMsg**
return
0
;
}
static
int
tqAck
(
tqGroupHandle
*
ghandle
,
t
mqAcks
*
pAcks
)
{
static
int
tqAck
(
TqGroupHandle
*
ghandle
,
T
mqAcks
*
pAcks
)
{
int32_t
ackNum
=
pAcks
->
ackNum
;
t
mqOneAck
*
acks
=
pAcks
->
acks
;
T
mqOneAck
*
acks
=
pAcks
->
acks
;
//double ptr for acks and list
int
i
=
0
;
t
qListHandle
*
node
=
ghandle
->
head
;
T
qListHandle
*
node
=
ghandle
->
head
;
int
ackCnt
=
0
;
t
qQueryMsg
*
pQuery
=
NULL
;
T
qQueryMsg
*
pQuery
=
NULL
;
while
(
i
<
ackNum
&&
node
->
next
)
{
if
(
acks
[
i
].
topicId
==
node
->
next
->
bufHandle
->
topicId
)
{
if
(
acks
[
i
].
topicId
==
node
->
next
->
bufHandle
.
topicId
)
{
ackCnt
++
;
tqAckOneTopic
(
node
->
next
->
bufHandle
,
&
acks
[
i
],
&
pQuery
);
}
else
if
(
acks
[
i
].
topicId
<
node
->
next
->
bufHandle
->
topicId
)
{
tqAckOneTopic
(
&
node
->
next
->
bufHandle
,
&
acks
[
i
],
&
pQuery
);
}
else
if
(
acks
[
i
].
topicId
<
node
->
next
->
bufHandle
.
topicId
)
{
i
++
;
}
else
{
node
=
node
->
next
;
...
...
@@ -73,12 +73,12 @@ static int tqAck(tqGroupHandle* ghandle, tmqAcks* pAcks) {
return
ackCnt
;
}
static
int
tqCommitTCGroup
(
t
qGroupHandle
*
handle
)
{
static
int
tqCommitTCGroup
(
T
qGroupHandle
*
handle
)
{
//persist modification into disk
return
0
;
}
int
tqCreateTCGroup
(
STQ
*
pTq
,
int64_t
topicId
,
int64_t
cgId
,
int64_t
cId
,
t
qGroupHandle
**
handle
)
{
int
tqCreateTCGroup
(
STQ
*
pTq
,
int64_t
topicId
,
int64_t
cgId
,
int64_t
cId
,
T
qGroupHandle
**
handle
)
{
//create in disk
return
0
;
}
...
...
@@ -99,13 +99,13 @@ int tqDropTCGroup(STQ* pTq, int64_t topicId, int64_t cgId, int64_t cId) {
return
0
;
}
static
int
tqFetch
(
t
qGroupHandle
*
ghandle
,
void
**
msg
)
{
t
qListHandle
*
head
=
ghandle
->
head
;
t
qListHandle
*
node
=
head
;
static
int
tqFetch
(
T
qGroupHandle
*
ghandle
,
void
**
msg
)
{
T
qListHandle
*
head
=
ghandle
->
head
;
T
qListHandle
*
node
=
head
;
int
totSize
=
0
;
//TODO: make it a macro
int
sizeLimit
=
4
*
1024
;
t
mqMsgContent
*
buffer
=
malloc
(
sizeLimit
);
T
mqMsgContent
*
buffer
=
malloc
(
sizeLimit
);
if
(
buffer
==
NULL
)
{
//TODO:memory insufficient
return
-
1
;
...
...
@@ -114,7 +114,7 @@ static int tqFetch(tqGroupHandle* ghandle, void** msg) {
//until all topic iterated or msgs over sizeLimit
while
(
node
->
next
)
{
node
=
node
->
next
;
tqBufferHandle
*
bufHandle
=
node
->
bufHandle
;
TqBufferHandle
*
bufHandle
=
&
node
->
bufHandle
;
int
idx
=
bufHandle
->
nextConsumeOffset
%
TQ_BUFFER_SIZE
;
if
(
bufHandle
->
buffer
[
idx
].
content
!=
NULL
&&
bufHandle
->
buffer
[
idx
].
offset
==
bufHandle
->
nextConsumeOffset
...
...
@@ -140,28 +140,23 @@ static int tqFetch(tqGroupHandle* ghandle, void** msg) {
}
}
}
if
(
totSize
==
0
)
{
//no msg
return
-
1
;
}
return
totSize
;
}
t
qGroupHandle
*
tqGetGroupHandle
(
STQ
*
pTq
,
int64_t
cId
)
{
T
qGroupHandle
*
tqGetGroupHandle
(
STQ
*
pTq
,
int64_t
cId
)
{
return
NULL
;
}
int
tqLaunchQuery
(
t
qGroupHandle
*
ghandle
)
{
int
tqLaunchQuery
(
T
qGroupHandle
*
ghandle
)
{
return
0
;
}
int
tqSendLaunchQuery
(
STQ
*
pTq
,
int64_t
topicId
,
int64_t
cgId
,
void
*
query
)
{
int
tqSendLaunchQuery
(
TqGroupHandle
*
gHandle
)
{
return
0
;
}
/*int tqMoveOffsetToNext(
t
qGroupHandle* ghandle) {*/
/*int tqMoveOffsetToNext(
T
qGroupHandle* ghandle) {*/
/*return 0;*/
/*}*/
...
...
@@ -176,13 +171,13 @@ int tqCommit(STQ* pTq) {
return
0
;
}
int
tqConsume
(
STQ
*
pTq
,
t
mqConsumeReq
*
pMsg
)
{
if
(
!
tqProtoCheck
((
t
mqMsgHead
*
)
pMsg
))
{
int
tqConsume
(
STQ
*
pTq
,
T
mqConsumeReq
*
pMsg
)
{
if
(
!
tqProtoCheck
((
T
mqMsgHead
*
)
pMsg
))
{
//proto version invalid
return
-
1
;
}
int64_t
clientId
=
pMsg
->
head
.
clientId
;
t
qGroupHandle
*
ghandle
=
tqGetGroupHandle
(
pTq
,
clientId
);
T
qGroupHandle
*
ghandle
=
tqGetGroupHandle
(
pTq
,
clientId
);
if
(
ghandle
==
NULL
)
{
//client not connect
return
-
1
;
...
...
@@ -194,9 +189,9 @@ int tqConsume(STQ* pTq, tmqConsumeReq* pMsg) {
}
}
tmqConsumeRsp
*
pRsp
=
(
t
mqConsumeRsp
*
)
pMsg
;
TmqConsumeRsp
*
pRsp
=
(
T
mqConsumeRsp
*
)
pMsg
;
if
(
tqFetch
(
ghandle
,
(
void
**
)
&
pRsp
->
msgs
)
<
0
)
{
if
(
tqFetch
(
ghandle
,
(
void
**
)
&
pRsp
->
msgs
)
<
=
0
)
{
//fetch error
return
-
1
;
}
...
...
@@ -209,14 +204,9 @@ int tqConsume(STQ* pTq, tmqConsumeReq* pMsg) {
return
0
;
}
int
tqSerializeGroupHandle
(
tqGroupHandle
*
gHandle
,
void
**
ppBytes
,
int32_t
offset
)
{
int
tqSerializeGroupHandle
(
TqGroupHandle
*
gHandle
,
void
**
ppBytes
)
{
//calculate size
int
sz
=
tqGetGHandleSSize
(
gHandle
);
if
(
sz
<=
0
)
{
//TODO: err
return
-
1
;
}
void
*
ptr
=
realloc
(
*
ppBytes
,
sz
);
if
(
ptr
==
NULL
)
{
free
(
ppBytes
);
...
...
@@ -224,29 +214,30 @@ int tqSerializeGroupHandle(tqGroupHandle *gHandle, void** ppBytes, int32_t offse
return
-
1
;
}
*
ppBytes
=
ptr
;
//do serializ
e
//do serializ
ation
*
(
int64_t
*
)
ptr
=
gHandle
->
cId
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
*
(
int64_t
*
)
ptr
=
gHandle
->
cgId
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
*
(
int32_t
*
)
ptr
=
gHandle
->
topicNum
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int32_t
));
if
(
gHandle
->
topicNum
>
0
)
{
tqSerializeListHandle
(
gHandle
->
head
,
p
pBytes
,
ptr
-
*
ppBytes
);
tqSerializeListHandle
(
gHandle
->
head
,
p
tr
);
}
return
0
;
}
int
tqSerializeListHandle
(
tqListHandle
*
listHandle
,
void
**
ppBytes
,
int32_t
offset
)
{
void
*
ptr
=
POINTER_SHIFT
(
*
ppBytes
,
offset
);
tqListHandle
*
node
=
listHandle
;
while
(
node
->
next
)
{
void
*
tqSerializeListHandle
(
TqListHandle
*
listHandle
,
void
*
ptr
)
{
TqListHandle
*
node
=
listHandle
;
ASSERT
(
node
!=
NULL
);
while
(
node
)
{
ptr
=
tqSerializeBufHandle
(
&
node
->
bufHandle
,
ptr
);
node
=
node
->
next
;
offset
=
tqSerializeBufHandle
(
node
->
bufHandle
,
ppBytes
,
offset
);
}
return
offset
;
return
ptr
;
}
int
tqSerializeBufHandle
(
tqBufferHandle
*
bufHandle
,
void
**
ppBytes
,
int32_t
offset
)
{
void
*
ptr
=
POINTER_SHIFT
(
*
ppBytes
,
offset
);
void
*
tqSerializeBufHandle
(
TqBufferHandle
*
bufHandle
,
void
*
ptr
)
{
*
(
int64_t
*
)
ptr
=
bufHandle
->
nextConsumeOffset
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
*
(
int64_t
*
)
ptr
=
bufHandle
->
topicId
;
...
...
@@ -256,41 +247,87 @@ int tqSerializeBufHandle(tqBufferHandle *bufHandle, void** ppBytes, int32_t offs
*
(
int32_t
*
)
ptr
=
bufHandle
->
tail
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int32_t
));
for
(
int
i
=
0
;
i
<
TQ_BUFFER_SIZE
;
i
++
)
{
int
sz
=
tqSerializeBufItem
(
&
bufHandle
->
buffer
[
i
],
ppBytes
,
ptr
-
*
ppBytes
);
ptr
=
POINTER_SHIFT
(
ptr
,
sz
);
ptr
=
tqSerializeBufItem
(
&
bufHandle
->
buffer
[
i
],
ptr
);
}
return
ptr
-
*
ppBytes
;
return
ptr
;
}
int
tqSerializeBufItem
(
tqBufferItem
*
bufItem
,
void
**
ppBytes
,
int32_t
offset
)
{
void
*
ptr
=
POINTER_SHIFT
(
*
ppBytes
,
offset
);
void
*
tqSerializeBufItem
(
TqBufferItem
*
bufItem
,
void
*
ptr
)
{
//TODO: do we need serialize this?
return
0
;
//mainly for executor
return
ptr
;
}
int
tqDeserializeGroupHandle
(
const
void
*
pBytes
,
tqGroupHandle
**
pGhandle
)
{
return
0
;
}
int
tqDeserializeListHandle
(
const
void
*
pBytes
,
tqListHandle
**
pListHandle
)
{
return
0
;
}
int
tqDeserializeBufHandle
(
const
void
*
pBytes
,
tqBufferHandle
**
pBufHandle
)
{
return
0
;
}
int
tqDeserializeBufItem
(
const
void
*
pBytes
,
tqBufferItem
**
pBufItem
)
{
return
0
;
const
void
*
tqDeserializeGroupHandle
(
const
void
*
pBytes
,
TqGroupHandle
*
gHandle
)
{
const
void
*
ptr
=
pBytes
;
gHandle
->
cId
=
*
(
int64_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
gHandle
->
cgId
=
*
(
int64_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
gHandle
->
ahandle
=
NULL
;
gHandle
->
topicNum
=
*
(
int32_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int32_t
));
gHandle
->
head
=
NULL
;
TqListHandle
*
node
=
gHandle
->
head
;
for
(
int
i
=
0
;
i
<
gHandle
->
topicNum
;
i
++
)
{
if
(
gHandle
->
head
==
NULL
)
{
if
((
node
=
malloc
(
sizeof
(
TqListHandle
)))
==
NULL
)
{
//TODO: error
return
NULL
;
}
node
->
next
=
NULL
;
ptr
=
tqDeserializeBufHandle
(
ptr
,
&
node
->
bufHandle
);
gHandle
->
head
=
node
;
}
else
{
node
->
next
=
malloc
(
sizeof
(
TqListHandle
));
if
(
node
->
next
==
NULL
)
{
//TODO: error
return
NULL
;
}
node
->
next
->
next
=
NULL
;
ptr
=
tqDeserializeBufHandle
(
ptr
,
&
node
->
next
->
bufHandle
);
node
=
node
->
next
;
}
}
return
ptr
;
}
const
void
*
tqDeserializeBufHandle
(
const
void
*
pBytes
,
TqBufferHandle
*
bufHandle
)
{
const
void
*
ptr
=
pBytes
;
bufHandle
->
nextConsumeOffset
=
*
(
int64_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
bufHandle
->
topicId
=
*
(
int64_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int64_t
));
bufHandle
->
head
=
*
(
int32_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int32_t
));
bufHandle
->
tail
=
*
(
int32_t
*
)
ptr
;
ptr
=
POINTER_SHIFT
(
ptr
,
sizeof
(
int32_t
));
for
(
int
i
=
0
;
i
<
TQ_BUFFER_SIZE
;
i
++
)
{
ptr
=
tqDeserializeBufItem
(
ptr
,
&
bufHandle
->
buffer
[
i
]);
}
return
ptr
;
}
int
tqGetGHandleSSize
(
const
tqGroupHandle
*
gHandle
)
{
return
0
;
const
void
*
tqDeserializeBufItem
(
const
void
*
pBytes
,
TqBufferItem
*
bufItem
)
{
return
pBytes
;
}
int
tqListHandleSSize
(
const
tqListHandle
*
listHandle
)
{
return
0
;
//TODO: make this a macro
int
tqGetGHandleSSize
(
const
TqGroupHandle
*
gHandle
)
{
return
sizeof
(
int64_t
)
*
2
+
sizeof
(
int32_t
)
+
gHandle
->
topicNum
*
tqBufHandleSSize
();
}
int
tqBufHandleSSize
(
const
tqBufferHandle
*
bufHandle
)
{
return
0
;
//TODO: make this a macro
int
tqBufHandleSSize
()
{
return
sizeof
(
int64_t
)
*
2
+
sizeof
(
int32_t
)
*
2
+
TQ_BUFFER_SIZE
*
tqBufItemSSize
();
}
int
tqBufItemSSize
(
const
tqBufferItem
*
bufItem
)
{
int
tqBufItemSSize
()
{
//TODO: do this need serialization?
//mainly for executor
return
0
;
}
source/server/vnode/tq/src/tqCommit.c
0 → 100644
浏览文件 @
a0d8b7df
/*
* 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/>.
*/
source/server/vnode/tq/src/tqMetaStore.c
0 → 100644
浏览文件 @
a0d8b7df
/*
* 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/>.
*/
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录