Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
7b82bd5e
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看板
提交
7b82bd5e
编写于
3月 27, 2023
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
差异文件
Merge branch '3.0' of
https://github.com/taosdata/TDengine
into enh/tsdb_optimize
上级
978c73fb
a5d4dfe2
变更
22
隐藏空白更改
内联
并排
Showing
22 changed file
with
107 addition
and
76 deletion
+107
-76
cmake/taostools_CMakeLists.txt.in
cmake/taostools_CMakeLists.txt.in
+1
-1
docs/en/12-taos-sql/12-distinguished.md
docs/en/12-taos-sql/12-distinguished.md
+1
-1
docs/en/13-operation/01-pkg-install.md
docs/en/13-operation/01-pkg-install.md
+5
-5
docs/zh/12-taos-sql/12-distinguished.md
docs/zh/12-taos-sql/12-distinguished.md
+1
-1
include/common/tmsg.h
include/common/tmsg.h
+3
-3
include/common/tmsgdef.h
include/common/tmsgdef.h
+2
-2
include/libs/sync/sync.h
include/libs/sync/sync.h
+1
-1
include/util/taoserror.h
include/util/taoserror.h
+1
-0
source/common/src/tmsg.c
source/common/src/tmsg.c
+2
-2
source/dnode/mgmt/mgmt_mnode/src/mmHandle.c
source/dnode/mgmt/mgmt_mnode/src/mmHandle.c
+1
-1
source/dnode/mgmt/mgmt_vnode/inc/vmInt.h
source/dnode/mgmt/mgmt_vnode/inc/vmInt.h
+0
-1
source/dnode/mgmt/mgmt_vnode/src/vmHandle.c
source/dnode/mgmt/mgmt_vnode/src/vmHandle.c
+1
-21
source/dnode/mgmt/mgmt_vnode/src/vmWorker.c
source/dnode/mgmt/mgmt_vnode/src/vmWorker.c
+0
-3
source/dnode/mnode/impl/src/mndDnode.c
source/dnode/mnode/impl/src/mndDnode.c
+9
-0
source/dnode/mnode/impl/src/mndVgroup.c
source/dnode/mnode/impl/src/mndVgroup.c
+23
-11
source/dnode/vnode/inc/vnode.h
source/dnode/vnode/inc/vnode.h
+0
-1
source/dnode/vnode/src/vnd/vnodeOpen.c
source/dnode/vnode/src/vnd/vnodeOpen.c
+0
-4
source/libs/function/src/tudf.c
source/libs/function/src/tudf.c
+12
-7
source/libs/sync/src/syncMain.c
source/libs/sync/src/syncMain.c
+23
-6
source/libs/sync/src/syncRequestVote.c
source/libs/sync/src/syncRequestVote.c
+1
-0
source/os/src/osTime.c
source/os/src/osTime.c
+16
-4
tools/shell/src/shellEngine.c
tools/shell/src/shellEngine.c
+4
-1
未找到文件。
cmake/taostools_CMakeLists.txt.in
浏览文件 @
7b82bd5e
...
...
@@ -2,7 +2,7 @@
# taos-tools
ExternalProject_Add(taos-tools
GIT_REPOSITORY https://github.com/taosdata/taos-tools.git
GIT_TAG
d11f210
GIT_TAG
2864326
SOURCE_DIR "${TD_SOURCE_DIR}/tools/taos-tools"
BINARY_DIR ""
#BUILD_IN_SOURCE TRUE
...
...
docs/en/12-taos-sql/12-distinguished.md
浏览文件 @
7b82bd5e
...
...
@@ -171,7 +171,7 @@ If you want to perform event window based query on the result set of a sub-query
For example, the diagram below illustrates the event windows generated by the query below:
```
sql
select
_wstart
,
_wend
,
count
(
*
)
from
t
start
with
c1
>
0
end
with
c2
<
10
select
_wstart
,
_wend
,
count
(
*
)
from
t
event_window
start
with
c1
>
0
end
with
c2
<
10
```
![
Event Window Illustration
](
./event_window.webp
)
...
...
docs/en/13-operation/01-pkg-install.md
浏览文件 @
7b82bd5e
...
...
@@ -15,14 +15,14 @@ About details of installing TDenine, please refer to [Installation Guide](../../
## Uninstall
<Tabs>
<TabItem
label=
"Uninstall apt-get"
value=
"aptremove"
>
<TabItem
label=
"Uninstall
by
apt-get"
value=
"aptremove"
>
Apt-get package of TDengine
can be uninstalled as below:
Uninstall package of TDengine by apt-get
can be uninstalled as below:
```
bash
$
sudo
apt-get remove tdengine
Reading package lists... Done
Building dependency tree
Building dependency tree
Reading state information... Done
The following packages will be REMOVED:
tdengine
...
...
@@ -35,7 +35,7 @@ TDengine is removed successfully!
```
Apt-get package of taosTools can be uninstalled as below
:
If you have installed taos-tools, please uninstall it first before uninstall TDengine. The command of uninstall is following
:
```
$ sudo apt remove taostools
...
...
@@ -168,7 +168,7 @@ Upgrading a running server is much more complex. First please check the version
-
Stop the cluster of TDengine
-
Uninstall old version and install new version
-
Start the cluster of TDengine
-
Execute simple queries, such as the ones executed prior to installing the new package, to make sure there is no data loss
-
Execute simple queries, such as the ones executed prior to installing the new package, to make sure there is no data loss
-
Run some simple data insertion statements to make sure the cluster works well
-
Restore business services
...
...
docs/zh/12-taos-sql/12-distinguished.md
浏览文件 @
7b82bd5e
...
...
@@ -163,7 +163,7 @@ SELECT COUNT(*), FIRST(ts) FROM temp_tb_1 SESSION(ts, tol_val);
以下面的 SQL 语句为例,事件窗口切分如图所示:
```
sql
select
_wstart
,
_wend
,
count
(
*
)
from
t
start
with
c1
>
0
end
with
c2
<
10
select
_wstart
,
_wend
,
count
(
*
)
from
t
event_window
start
with
c1
>
0
end
with
c2
<
10
```
![
TDengine Database 事件窗口示意图
](
./event_window.webp
)
...
...
include/common/tmsg.h
浏览文件 @
7b82bd5e
...
...
@@ -1670,10 +1670,10 @@ int32_t tDeserializeSBalanceVgroupLeaderReq(void* buf, int32_t bufLen, SBalanceV
typedef
struct
{
int32_t
vgId
;
}
SForce
Election
Req
;
}
SForce
BecomeFollower
Req
;
int32_t
tSerializeSForce
ElectionReq
(
void
*
buf
,
int32_t
bufLen
,
SForceElection
Req
*
pReq
);
int32_t
tDeserializeSForce
ElectionReq
(
void
*
buf
,
int32_t
bufLen
,
SForceElection
Req
*
pReq
);
int32_t
tSerializeSForce
BecomeFollowerReq
(
void
*
buf
,
int32_t
bufLen
,
SForceBecomeFollower
Req
*
pReq
);
int32_t
tDeserializeSForce
BecomeFollowerReq
(
void
*
buf
,
int32_t
bufLen
,
SForceBecomeFollower
Req
*
pReq
);
typedef
struct
{
int32_t
vgId
;
...
...
include/common/tmsgdef.h
浏览文件 @
7b82bd5e
...
...
@@ -83,7 +83,6 @@ enum {
TD_DEF_MSG_TYPE
(
TDMT_DND_CONFIG_DNODE
,
"config-dnode"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_DND_SYSTABLE_RETRIEVE
,
"dnode-retrieve"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_DND_MAX_MSG
,
"dnd-max"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_DND_FORCE_ELECTION
,
"balance-force-election"
,
NULL
,
NULL
)
TD_NEW_MSG_SEG
(
TDMT_MND_MSG
)
TD_DEF_MSG_TYPE
(
TDMT_MND_CONNECT
,
"connect"
,
NULL
,
NULL
)
...
...
@@ -166,7 +165,6 @@ enum {
TD_DEF_MSG_TYPE
(
TDMT_MND_AUTH
,
"auth"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_APPLY_MSG
,
"mnode-apply"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_BALANCE_VGROUP
,
"balance-vgroup"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_BALANCE_VGROUP_LEADER
,
"balance-vgroup-leader"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_MERGE_VGROUP
,
"merge-vgroup"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_REDISTRIBUTE_VGROUP
,
"redistribute-vgroup"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_SPLIT_VGROUP
,
"split-vgroup"
,
NULL
,
NULL
)
...
...
@@ -177,6 +175,7 @@ enum {
// TD_DEF_MSG_TYPE(TDMT_MND_STREAM_CHECKPOINT_TIMER, "stream-checkpoint-tmr", NULL, NULL)
// TD_DEF_MSG_TYPE(TDMT_MND_STREAM_BEGIN_CHECKPOINT, "stream-begin-checkpoint", NULL, NULL)
TD_DEF_MSG_TYPE
(
TDMT_MND_MAX_MSG
,
"mnd-max"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_MND_BALANCE_VGROUP_LEADER
,
"balance-vgroup-leader"
,
NULL
,
NULL
)
TD_NEW_MSG_SEG
(
TDMT_VND_MSG
)
TD_DEF_MSG_TYPE
(
TDMT_VND_SUBMIT
,
"submit"
,
SSubmitReq
,
SSubmitRsp
)
...
...
@@ -288,6 +287,7 @@ enum {
TD_DEF_MSG_TYPE
(
TDMT_SYNC_PRE_SNAPSHOT
,
"sync-pre-snapshot"
,
NULL
,
NULL
)
// no longer used
TD_DEF_MSG_TYPE
(
TDMT_SYNC_PRE_SNAPSHOT_REPLY
,
"sync-pre-snapshot-reply"
,
NULL
,
NULL
)
// no longer used
TD_DEF_MSG_TYPE
(
TDMT_SYNC_MAX_MSG
,
"sync-max"
,
NULL
,
NULL
)
TD_DEF_MSG_TYPE
(
TDMT_SYNC_FORCE_FOLLOWER
,
"sync-force-become-follower"
,
NULL
,
NULL
)
TD_NEW_MSG_SEG
(
TDMT_VND_STREAM_MSG
)
TD_DEF_MSG_TYPE
(
TDMT_VND_STREAM_TRIGGER
,
"vnode-stream-trigger"
,
NULL
,
NULL
)
...
...
include/libs/sync/sync.h
浏览文件 @
7b82bd5e
...
...
@@ -246,7 +246,7 @@ bool syncIsReadyForRead(int64_t rid);
bool
syncSnapshotSending
(
int64_t
rid
);
bool
syncSnapshotRecving
(
int64_t
rid
);
int32_t
syncSendTimeoutRsp
(
int64_t
rid
,
int64_t
seq
);
int32_t
sync
LeaderForceElection
(
int64_t
rid
);
int32_t
sync
ForceBecomeFollower
(
SSyncNode
*
ths
,
const
SRpcMsg
*
pRpcMsg
);
SSyncState
syncGetState
(
int64_t
rid
);
void
syncGetRetryEpSet
(
int64_t
rid
,
SEpSet
*
pEpSet
);
...
...
include/util/taoserror.h
浏览文件 @
7b82bd5e
...
...
@@ -223,6 +223,7 @@ int32_t* taosGetErrno();
// #define TSDB_CODE_MND_NOT_READY TAOS_DEF_ERROR_CODE(0, 0x033C) // 2.x
// #define TSDB_CODE_MND_DNODE_ID_NOT_CONFIGUREDTAOS_DEF_ERROR_CODE(0, 0x033D) // 2.x
// #define TSDB_CODE_MND_DNODE_EP_NOT_CONFIGUREDTAOS_DEF_ERROR_CODE(0, 0x033E) // 2.x
#define TSDB_CODE_MND_DNODE_DIFF_CLUSTER TAOS_DEF_ERROR_CODE(0, 0x033F) // internal
// mnode-acct
#define TSDB_CODE_MND_ACCT_ALREADY_EXIST TAOS_DEF_ERROR_CODE(0, 0x0340)
...
...
source/common/src/tmsg.c
浏览文件 @
7b82bd5e
...
...
@@ -4569,7 +4569,7 @@ int32_t tDeserializeSSplitVgroupReq(void *buf, int32_t bufLen, SSplitVgroupReq *
return
0
;
}
int32_t
tSerializeSForce
ElectionReq
(
void
*
buf
,
int32_t
bufLen
,
SForceElection
Req
*
pReq
)
{
int32_t
tSerializeSForce
BecomeFollowerReq
(
void
*
buf
,
int32_t
bufLen
,
SForceBecomeFollower
Req
*
pReq
)
{
SEncoder
encoder
=
{
0
};
tEncoderInit
(
&
encoder
,
buf
,
bufLen
);
...
...
@@ -4582,7 +4582,7 @@ int32_t tSerializeSForceElectionReq(void *buf, int32_t bufLen, SForceElectionReq
return
tlen
;
}
int32_t
tDeserializeSForce
ElectionReq
(
void
*
buf
,
int32_t
bufLen
,
SForceElection
Req
*
pReq
)
{
int32_t
tDeserializeSForce
BecomeFollowerReq
(
void
*
buf
,
int32_t
bufLen
,
SForceBecomeFollower
Req
*
pReq
)
{
SDecoder
decoder
=
{
0
};
tDecoderInit
(
&
decoder
,
buf
,
bufLen
);
...
...
source/dnode/mgmt/mgmt_mnode/src/mmHandle.c
浏览文件 @
7b82bd5e
...
...
@@ -92,7 +92,6 @@ SArray *mmGetMsgHandles() {
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_CREATE_VNODE_RSP
,
mmPutMsgToWriteQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_DROP_VNODE_RSP
,
mmPutMsgToWriteQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_CONFIG_DNODE_RSP
,
mmPutMsgToReadQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_FORCE_ELECTION_RSP
,
mmPutMsgToWriteQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_MND_CONNECT
,
mmPutMsgToReadQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_MND_CREATE_ACCT
,
mmPutMsgToWriteQueue
,
0
)
==
NULL
)
goto
_OVER
;
...
...
@@ -205,6 +204,7 @@ SArray *mmGetMsgHandles() {
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_PRE_SNAPSHOT_REPLY
,
mmPutMsgToSyncQueue
,
1
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_HEARTBEAT
,
mmPutMsgToSyncCtrlQueue
,
1
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_HEARTBEAT_REPLY
,
mmPutMsgToSyncCtrlQueue
,
1
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_FORCE_FOLLOWER_RSP
,
mmPutMsgToWriteQueue
,
0
)
==
NULL
)
goto
_OVER
;
code
=
0
;
...
...
source/dnode/mgmt/mgmt_vnode/inc/vmInt.h
浏览文件 @
7b82bd5e
...
...
@@ -86,7 +86,6 @@ void vmCloseVnode(SVnodeMgmt *pMgmt, SVnodeObj *pVnode, bool commitAndRemo
// vmHandle.c
SArray
*
vmGetMsgHandles
();
int32_t
vmProcessCreateVnodeReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
);
int32_t
vmProcessForceElectionReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
);
int32_t
vmProcessDropVnodeReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
);
int32_t
vmProcessAlterVnodeReplicaReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
);
int32_t
vmProcessDisableVnodeWriteReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
);
...
...
source/dnode/mgmt/mgmt_vnode/src/vmHandle.c
浏览文件 @
7b82bd5e
...
...
@@ -304,26 +304,6 @@ int32_t vmProcessDisableVnodeWriteReq(SVnodeMgmt *pMgmt, SRpcMsg *pMsg) {
return
0
;
}
int32_t
vmProcessForceElectionReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
){
SForceElectionReq
req
=
{
0
};
if
(
tDeserializeSForceElectionReq
(
pMsg
->
pCont
,
pMsg
->
contLen
,
&
req
)
!=
0
)
{
terrno
=
TSDB_CODE_INVALID_MSG
;
return
-
1
;
}
SVnodeObj
*
pVnode
=
vmAcquireVnode
(
pMgmt
,
req
.
vgId
);
if
(
pVnode
==
NULL
)
{
dError
(
"vgId:%d, failed to alter hashrange since %s"
,
req
.
vgId
,
terrstr
());
terrno
=
TSDB_CODE_VND_NOT_EXIST
;
return
-
1
;
}
vnodeForceElection
(
pVnode
->
pImpl
);
return
0
;
}
int32_t
vmProcessAlterHashRangeReq
(
SVnodeMgmt
*
pMgmt
,
SRpcMsg
*
pMsg
)
{
SAlterVnodeHashRangeReq
req
=
{
0
};
if
(
tDeserializeSAlterVnodeHashRangeReq
(
pMsg
->
pCont
,
pMsg
->
contLen
,
&
req
)
!=
0
)
{
...
...
@@ -568,7 +548,6 @@ SArray *vmGetMsgHandles() {
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_VND_TRIM
,
vmPutMsgToWriteQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_CREATE_VNODE
,
vmPutMsgToMgmtQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_DROP_VNODE
,
vmPutMsgToMgmtQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_DND_FORCE_ELECTION
,
vmPutMsgToMgmtQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_TIMEOUT
,
vmPutMsgToSyncQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_CLIENT_REQUEST
,
vmPutMsgToSyncQueue
,
0
)
==
NULL
)
goto
_OVER
;
...
...
@@ -586,6 +565,7 @@ SArray *vmGetMsgHandles() {
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_HEARTBEAT
,
vmPutMsgToSyncCtrlQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_HEARTBEAT_REPLY
,
vmPutMsgToSyncCtrlQueue
,
0
)
==
NULL
)
goto
_OVER
;
if
(
dmSetMgmtHandle
(
pArray
,
TDMT_SYNC_FORCE_FOLLOWER
,
vmPutMsgToSyncQueue
,
0
)
==
NULL
)
goto
_OVER
;
code
=
0
;
...
...
source/dnode/mgmt/mgmt_vnode/src/vmWorker.c
浏览文件 @
7b82bd5e
...
...
@@ -37,9 +37,6 @@ static void vmProcessMgmtQueue(SQueueInfo *pInfo, SRpcMsg *pMsg) {
case
TDMT_DND_CREATE_VNODE
:
code
=
vmProcessCreateVnodeReq
(
pMgmt
,
pMsg
);
break
;
case
TDMT_DND_FORCE_ELECTION
:
code
=
vmProcessForceElectionReq
(
pMgmt
,
pMsg
);
break
;
case
TDMT_DND_DROP_VNODE
:
code
=
vmProcessDropVnodeReq
(
pMgmt
,
pMsg
);
break
;
...
...
source/dnode/mnode/impl/src/mndDnode.c
浏览文件 @
7b82bd5e
...
...
@@ -25,6 +25,7 @@
#include "mndUser.h"
#include "mndVgroup.h"
#include "tmisce.h"
#include "mndCluster.h"
#define TSDB_DNODE_VER_NUMBER 1
#define TSDB_DNODE_RESERVE_SIZE 64
...
...
@@ -366,6 +367,14 @@ static int32_t mndProcessStatusReq(SRpcMsg *pReq) {
goto
_OVER
;
}
int64_t
clusterid
=
mndGetClusterId
(
pMnode
);
if
(
statusReq
.
clusterId
!=
0
&&
statusReq
.
clusterId
!=
clusterid
)
{
code
=
TSDB_CODE_MND_DNODE_DIFF_CLUSTER
;
mWarn
(
"dnode:%d, %s, its clusterid:%"
PRId64
" differ from current cluster:%"
PRId64
", code:0x%x"
,
statusReq
.
dnodeId
,
statusReq
.
dnodeEp
,
statusReq
.
clusterId
,
clusterid
,
code
);
goto
_OVER
;
}
if
(
statusReq
.
dnodeId
==
0
)
{
pDnode
=
mndAcquireDnodeByEp
(
pMnode
,
statusReq
.
dnodeEp
);
if
(
pDnode
==
NULL
)
{
...
...
source/dnode/mnode/impl/src/mndVgroup.c
浏览文件 @
7b82bd5e
...
...
@@ -61,7 +61,7 @@ int32_t mndInitVgroup(SMnode *pMnode) {
mndSetMsgHandle
(
pMnode
,
TDMT_DND_DROP_VNODE_RSP
,
mndTransProcessRsp
);
mndSetMsgHandle
(
pMnode
,
TDMT_VND_COMPACT_RSP
,
mndTransProcessRsp
);
mndSetMsgHandle
(
pMnode
,
TDMT_VND_DISABLE_WRITE_RSP
,
mndTransProcessRsp
);
mndSetMsgHandle
(
pMnode
,
TDMT_
DND_FORCE_ELECTION
_RSP
,
mndTransProcessRsp
);
mndSetMsgHandle
(
pMnode
,
TDMT_
SYNC_FORCE_FOLLOWER
_RSP
,
mndTransProcessRsp
);
mndSetMsgHandle
(
pMnode
,
TDMT_MND_REDISTRIBUTE_VGROUP
,
mndProcessRedistributeVgroupMsg
);
mndSetMsgHandle
(
pMnode
,
TDMT_MND_SPLIT_VGROUP
,
mndProcessSplitVgroupMsg
);
...
...
@@ -1779,17 +1779,18 @@ _OVER:
return
code
;
}
static
void
*
mndBuildSForce
Election
Req
(
SMnode
*
pMnode
,
SVgObj
*
pVgroup
,
int32_t
dnodeId
,
static
void
*
mndBuildSForce
BecomeFollower
Req
(
SMnode
*
pMnode
,
SVgObj
*
pVgroup
,
int32_t
dnodeId
,
int32_t
*
pContLen
)
{
SForce
Election
Req
balanceReq
=
{
SForce
BecomeFollower
Req
balanceReq
=
{
.
vgId
=
pVgroup
->
vgId
,
};
int32_t
contLen
=
tSerializeSForce
Election
Req
(
NULL
,
0
,
&
balanceReq
);
int32_t
contLen
=
tSerializeSForce
BecomeFollower
Req
(
NULL
,
0
,
&
balanceReq
);
if
(
contLen
<
0
)
{
terrno
=
TSDB_CODE_OUT_OF_MEMORY
;
return
NULL
;
}
contLen
+=
sizeof
(
SMsgHead
);
void
*
pReq
=
taosMemoryMalloc
(
contLen
);
if
(
pReq
==
NULL
)
{
...
...
@@ -1797,9 +1798,13 @@ static void *mndBuildSForceElectionReq(SMnode *pMnode, SVgObj *pVgroup, int32_t
return
NULL
;
}
tSerializeSForceElectionReq
((
char
*
)
pReq
,
contLen
,
&
balanceReq
);
SMsgHead
*
pHead
=
pReq
;
pHead
->
contLen
=
htonl
(
contLen
);
pHead
->
vgId
=
htonl
(
pVgroup
->
vgId
);
tSerializeSForceBecomeFollowerReq
((
char
*
)
pReq
+
sizeof
(
SMsgHead
),
contLen
,
&
balanceReq
);
*
pContLen
=
contLen
;
return
pReq
;
return
pReq
;
}
int32_t
mndAddBalanceVgroupLeaderAction
(
SMnode
*
pMnode
,
STrans
*
pTrans
,
SVgObj
*
pVgroup
,
int32_t
dnodeId
)
{
...
...
@@ -1811,12 +1816,12 @@ int32_t mndAddBalanceVgroupLeaderAction(SMnode *pMnode, STrans *pTrans, SVgObj *
mndReleaseDnode
(
pMnode
,
pDnode
);
int32_t
contLen
=
0
;
void
*
pReq
=
mndBuildSForce
Election
Req
(
pMnode
,
pVgroup
,
dnodeId
,
&
contLen
);
void
*
pReq
=
mndBuildSForce
BecomeFollower
Req
(
pMnode
,
pVgroup
,
dnodeId
,
&
contLen
);
if
(
pReq
==
NULL
)
return
-
1
;
action
.
pCont
=
pReq
;
action
.
contLen
=
contLen
;
action
.
msgType
=
TDMT_
DND_FORCE_ELECTION
;
action
.
msgType
=
TDMT_
SYNC_FORCE_FOLLOWER
;
if
(
mndTransAppendRedoAction
(
pTrans
,
&
action
)
!=
0
)
{
taosMemoryFree
(
pReq
);
...
...
@@ -1832,13 +1837,20 @@ int32_t mndAddVgroupBalanceToTrans(SMnode *pMnode, SVgObj *pVgroup, STrans *pTra
int32_t
vgid
=
pVgroup
->
vgId
;
int8_t
replica
=
pVgroup
->
replica
;
if
(
pVgroup
->
replica
<=
1
)
{
if
(
pVgroup
->
replica
<=
1
)
{
mInfo
(
"trans:%d, vgid:%d no need to balance, replica:%d"
,
pTrans
->
id
,
vgid
,
replica
);
return
-
1
;
}
int32_t
index
=
vgid
%
replica
;
int32_t
dnodeId
=
pVgroup
->
vnodeGid
[
index
].
dnodeId
;
int32_t
dnodeId
=
pVgroup
->
vnodeGid
[
0
].
dnodeId
;
for
(
int
i
=
0
;
i
<
replica
;
i
++
)
{
if
(
pVgroup
->
vnodeGid
[
i
].
syncState
==
TAOS_SYNC_STATE_LEADER
){
dnodeId
=
pVgroup
->
vnodeGid
[
i
].
dnodeId
;
break
;
}
}
bool
exist
=
false
;
bool
online
=
false
;
...
...
source/dnode/vnode/inc/vnode.h
浏览文件 @
7b82bd5e
...
...
@@ -56,7 +56,6 @@ void vnodeDestroy(const char *path, STfs *pTfs);
SVnode
*
vnodeOpen
(
const
char
*
path
,
STfs
*
pTfs
,
SMsgCb
msgCb
);
void
vnodePreClose
(
SVnode
*
pVnode
);
void
vnodePostClose
(
SVnode
*
pVnode
);
void
vnodeForceElection
(
SVnode
*
pVnode
);
void
vnodeSyncCheckTimeout
(
SVnode
*
pVnode
);
void
vnodeClose
(
SVnode
*
pVnode
);
int32_t
vnodeSyncCommit
(
SVnode
*
pVnode
);
...
...
source/dnode/vnode/src/vnd/vnodeOpen.c
浏览文件 @
7b82bd5e
...
...
@@ -380,10 +380,6 @@ void vnodePreClose(SVnode *pVnode) {
void
vnodePostClose
(
SVnode
*
pVnode
)
{
vnodeSyncPostClose
(
pVnode
);
}
void
vnodeForceElection
(
SVnode
*
pVnode
)
{
syncLeaderForceElection
(
pVnode
->
sync
);
}
void
vnodeClose
(
SVnode
*
pVnode
)
{
if
(
pVnode
)
{
tsem_wait
(
&
pVnode
->
canCommit
);
...
...
source/libs/function/src/tudf.c
浏览文件 @
7b82bd5e
...
...
@@ -1210,14 +1210,19 @@ int32_t udfAggFinalize(struct SqlFunctionCtx *pCtx, SSDataBlock *pBlock) {
fnError
(
"udfAggFinalize error. doCallUdfAggFinalize step. udf code:%d"
,
udfCallCode
);
GET_RES_INFO
(
pCtx
)
->
numOfRes
=
0
;
}
else
{
if
(
resultBuf
.
bufLen
<=
session
->
bytes
)
{
memcpy
(
udfRes
->
finalResBuf
,
resultBuf
.
buf
,
resultBuf
.
bufLen
);
udfRes
->
finalResNum
=
resultBuf
.
numOfResult
;
GET_RES_INFO
(
pCtx
)
->
numOfRes
=
udfRes
->
finalResNum
;
}
else
{
fnError
(
"udfc inter buf size %d is greater than function output size %d"
,
resultBuf
.
bufLen
,
session
->
bytes
);
if
(
resultBuf
.
numOfResult
==
0
)
{
udfRes
->
finalResNum
=
0
;
GET_RES_INFO
(
pCtx
)
->
numOfRes
=
0
;
udfCallCode
=
TSDB_CODE_UDF_INVALID_OUTPUT_TYPE
;
}
else
{
if
(
resultBuf
.
bufLen
<=
session
->
bytes
)
{
memcpy
(
udfRes
->
finalResBuf
,
resultBuf
.
buf
,
resultBuf
.
bufLen
);
udfRes
->
finalResNum
=
resultBuf
.
numOfResult
;
GET_RES_INFO
(
pCtx
)
->
numOfRes
=
udfRes
->
finalResNum
;
}
else
{
fnError
(
"udfc inter buf size %d is greater than function output size %d"
,
resultBuf
.
bufLen
,
session
->
bytes
);
GET_RES_INFO
(
pCtx
)
->
numOfRes
=
0
;
udfCallCode
=
TSDB_CODE_UDF_INVALID_OUTPUT_TYPE
;
}
}
}
...
...
source/libs/sync/src/syncMain.c
浏览文件 @
7b82bd5e
...
...
@@ -37,6 +37,7 @@
#include "syncVoteMgr.h"
#include "tglobal.h"
#include "tref.h"
#include "syncUtil.h"
static
void
syncNodeEqPingTimer
(
void
*
param
,
void
*
tmrId
);
static
void
syncNodeEqElectTimer
(
void
*
param
,
void
*
tmrId
);
...
...
@@ -206,6 +207,9 @@ int32_t syncProcessMsg(int64_t rid, SRpcMsg* pMsg) {
case
TDMT_SYNC_LOCAL_CMD
:
code
=
syncNodeOnLocalCmd
(
pSyncNode
,
pMsg
);
break
;
case
TDMT_SYNC_FORCE_FOLLOWER
:
code
=
syncForceBecomeFollower
(
pSyncNode
,
pMsg
);
break
;
default:
terrno
=
TSDB_CODE_MSG_NOT_PROCESSED
;
code
=
-
1
;
...
...
@@ -228,13 +232,18 @@ int32_t syncLeaderTransfer(int64_t rid) {
return
ret
;
}
int32_t
syncLeaderForceElection
(
int64_t
rid
)
{
SSyncNode
*
pSyncNode
=
syncNodeAcquire
(
rid
);
if
(
pSyncNode
==
NULL
)
return
-
1
;
int32_t
syncForceBecomeFollower
(
SSyncNode
*
ths
,
const
SRpcMsg
*
pRpcMsg
)
{
syncNodeBecomeFollower
(
ths
,
"force election"
);
int32_t
ret
=
syncNodeElect
(
pSyncNode
);
syncNodeRelease
(
pSyncNode
);
return
ret
;
SRpcMsg
rsp
=
{
.
code
=
0
,
.
pCont
=
pRpcMsg
->
info
.
rsp
,
.
contLen
=
pRpcMsg
->
info
.
rspLen
,
.
info
=
pRpcMsg
->
info
,
};
tmsgSendRsp
(
&
rsp
);
return
0
;
}
int32_t
syncSendTimeoutRsp
(
int64_t
rid
,
int64_t
seq
)
{
...
...
@@ -2295,6 +2304,14 @@ int32_t syncNodeOnHeartbeat(SSyncNode* ths, const SRpcMsg* pRpcMsg) {
int64_t
timeDiff
=
tsMs
-
pMsg
->
timeStamp
;
syncLogRecvHeartbeat
(
ths
,
pMsg
,
timeDiff
,
tbuf
);
if
(
!
syncNodeInRaftGroup
(
ths
,
&
pMsg
->
srcId
))
{
sWarn
(
"vgId:%d, drop heartbeat msg from dnode:%d, because it come from another cluster:%d, differ from current "
"cluster:%d"
,
ths
->
vgId
,
DID
(
&
(
pMsg
->
srcId
)),
CID
(
&
(
pMsg
->
srcId
)),
CID
(
&
(
ths
->
myRaftId
)));
return
0
;
}
SRpcMsg
rpcMsg
=
{
0
};
(
void
)
syncBuildHeartbeatReply
(
&
rpcMsg
,
ths
->
vgId
);
SyncTerm
currentTerm
=
raftStoreGetTerm
(
ths
);
...
...
source/libs/sync/src/syncRequestVote.c
浏览文件 @
7b82bd5e
...
...
@@ -20,6 +20,7 @@
#include "syncRaftStore.h"
#include "syncUtil.h"
#include "syncVoteMgr.h"
#include "syncUtil.h"
// TLA+ Spec
// HandleRequestVoteRequest(i, j, m) ==
...
...
source/os/src/osTime.c
浏览文件 @
7b82bd5e
...
...
@@ -413,12 +413,16 @@ struct tm *taosLocalTime(const time_t *timep, struct tm *result) {
}
#ifdef WINDOWS
if
(
*
timep
<
0
)
{
return
NULL
;
// TODO: bugs in following code
SYSTEMTIME
ss
,
s
;
FILETIME
ff
,
f
;
LARGE_INTEGER
offset
;
struct
tm
tm1
;
time_t
tt
=
0
;
localtime_s
(
&
tm1
,
&
tt
);
if
(
localtime_s
(
&
tm1
,
&
tt
)
!=
0
)
{
return
NULL
;
}
ss
.
wYear
=
tm1
.
tm_year
+
1900
;
ss
.
wMonth
=
tm1
.
tm_mon
+
1
;
ss
.
wDay
=
tm1
.
tm_mday
;
...
...
@@ -444,7 +448,9 @@ struct tm *taosLocalTime(const time_t *timep, struct tm *result) {
result
->
tm_yday
=
0
;
result
->
tm_isdst
=
0
;
}
else
{
localtime_s
(
result
,
timep
);
if
(
localtime_s
(
result
,
timep
)
!=
0
)
{
return
NULL
;
}
}
#else
localtime_r
(
timep
,
result
);
...
...
@@ -469,12 +475,16 @@ struct tm *taosLocalTimeNolock(struct tm *result, const time_t *timep, int dst)
}
#ifdef WINDOWS
if
(
*
timep
<
0
)
{
return
NULL
;
// TODO: bugs in following code
SYSTEMTIME
ss
,
s
;
FILETIME
ff
,
f
;
LARGE_INTEGER
offset
;
struct
tm
tm1
;
time_t
tt
=
0
;
localtime_s
(
&
tm1
,
&
tt
);
if
(
localtime_s
(
&
tm1
,
&
tt
)
!=
0
)
{
return
NULL
;
}
ss
.
wYear
=
tm1
.
tm_year
+
1900
;
ss
.
wMonth
=
tm1
.
tm_mon
+
1
;
ss
.
wDay
=
tm1
.
tm_mday
;
...
...
@@ -500,7 +510,9 @@ struct tm *taosLocalTimeNolock(struct tm *result, const time_t *timep, int dst)
result
->
tm_yday
=
0
;
result
->
tm_isdst
=
0
;
}
else
{
localtime_s
(
result
,
timep
);
if
(
localtime_s
(
result
,
timep
)
!=
0
)
{
return
NULL
;
}
}
#elif defined(LINUX)
time_t
secsMin
=
60
,
secsHour
=
3600
,
secsDay
=
3600
*
24
;
...
...
tools/shell/src/shellEngine.c
浏览文件 @
7b82bd5e
...
...
@@ -291,7 +291,10 @@ char *shellFormatTimestamp(char *buf, int64_t val, int32_t precision) {
}
struct
tm
ptm
=
{
0
};
taosLocalTime
(
&
tt
,
&
ptm
);
if
(
taosLocalTime
(
&
tt
,
&
ptm
)
==
NULL
)
{
sprintf
(
buf
,
"NaN"
);
return
buf
;
}
size_t
pos
=
strftime
(
buf
,
35
,
"%Y-%m-%d %H:%M:%S"
,
&
ptm
);
if
(
precision
==
TSDB_TIME_PRECISION_NANO
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录