Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
b0c06c55
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看板
提交
b0c06c55
编写于
3月 04, 2023
作者:
H
Haojun Liao
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'feature/3_liaohj' of github.com:taosdata/tdengine into feature/3_liaohj
上级
dfeed5a4
566d233c
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
63 addition
and
1 deletion
+63
-1
source/libs/transport/src/transCli.c
source/libs/transport/src/transCli.c
+63
-1
未找到文件。
source/libs/transport/src/transCli.c
浏览文件 @
b0c06c55
...
...
@@ -13,7 +13,6 @@
*/
#include "transComm.h"
#include "tutil.h"
typedef
struct
{
int32_t
numOfConn
;
...
...
@@ -121,6 +120,9 @@ typedef struct SCliThrd {
SCliMsg
*
stopMsg
;
bool
quit
;
int
newConnCount
;
SHashObj
*
msgCount
;
}
SCliThrd
;
typedef
struct
SCliObj
{
...
...
@@ -423,6 +425,21 @@ void cliHandleResp(SCliConn* conn) {
tDebug
(
"%s conn %p ref by app"
,
CONN_GET_INST_LABEL
(
conn
),
conn
);
}
// if (TMSG_INFO(pHead->msgType - 1) != 0) {
// char buf[128] = {0};
// sprintf(buf, "%s", TMSG_INFO(pHead->msgType - 1));
// int* count = taosHashGet(pThrd->msgCount, TMSG_INFO(pHead->msgType - 1), strlen(TMSG_INFO(pHead->msgType - 1)));
// if (NULL == 0) {
// int localCount = 1;
// taosHashPut(pThrd->msgCount, TMSG_INFO(pHead->msgType - 1), strlen(TMSG_INFO(pHead->msgType - 1)), &localCount,
// sizeof(localCount));
// } else {
// int localCount = *count - 1;
// taosHashPut(pThrd->msgCount, TMSG_INFO(pHead->msgType - 1), strlen(TMSG_INFO(pHead->msgType - 1)), &localCount,
// sizeof(localCount));
// }
// }
STraceId
*
trace
=
&
transMsg
.
info
.
traceId
;
tGDebug
(
"%s conn %p %s received from %s, local info:%s, len:%d, code str:%s"
,
CONN_GET_INST_LABEL
(
conn
),
conn
,
TMSG_INFO
(
pHead
->
msgType
),
conn
->
dst
,
conn
->
src
,
pHead
->
msgLen
,
tstrerror
(
transMsg
.
code
));
...
...
@@ -1098,6 +1115,20 @@ void cliSend(SCliConn* pConn) {
msgLen
=
(
int32_t
)
ntohl
((
uint32_t
)(
pHead
->
msgLen
));
}
if
((
pHead
->
msgType
>
TDMT_VND_TMQ_MSG
&&
pHead
->
msgType
<
TDMT_VND_TMQ_MAX_MSG
)
||
(
pHead
->
msgType
>
TDMT_MND_MSG
&&
pHead
->
msgType
<
TDMT_MND_MAX_MSG
))
{
char
buf
[
128
]
=
{
0
};
sprintf
(
buf
,
"%s"
,
TMSG_INFO
(
pHead
->
msgType
));
int
*
count
=
taosHashGet
(
pThrd
->
msgCount
,
buf
,
sizeof
(
buf
));
if
(
NULL
==
0
)
{
int
localCount
=
1
;
taosHashPut
(
pThrd
->
msgCount
,
buf
,
sizeof
(
buf
),
&
localCount
,
sizeof
(
localCount
));
}
else
{
int
localCount
=
*
count
+
1
;
taosHashPut
(
pThrd
->
msgCount
,
buf
,
sizeof
(
buf
),
&
localCount
,
sizeof
(
localCount
));
}
}
tGDebug
(
"%s conn %p %s is sent to %s, local info %s, len:%d"
,
CONN_GET_INST_LABEL
(
pConn
),
pConn
,
TMSG_INFO
(
pHead
->
msgType
),
pConn
->
dst
,
pConn
->
src
,
msgLen
);
...
...
@@ -1173,6 +1204,7 @@ static void cliHandleBatchReq(SCliBatch* pBatch, SCliThrd* pThrd) {
addr
.
sin_port
=
(
uint16_t
)
htons
(
pList
->
port
);
tTrace
(
"%s conn %p try to connect to %s"
,
pTransInst
->
label
,
conn
,
pList
->
dst
);
pThrd
->
newConnCount
++
;
int32_t
fd
=
taosCreateSocketWithTimeout
(
TRANS_CONN_TIMEOUT
*
10
);
if
(
fd
==
-
1
)
{
tError
(
"%s conn %p failed to create socket, reason:%s"
,
transLabel
(
pTransInst
),
conn
,
...
...
@@ -1546,6 +1578,7 @@ void cliHandleReq(SCliMsg* pMsg, SCliThrd* pThrd) {
addr
.
sin_port
=
(
uint16_t
)
htons
(
port
);
tGTrace
(
"%s conn %p try to connect to %s"
,
pTransInst
->
label
,
conn
,
conn
->
ip
);
pThrd
->
newConnCount
++
;
int32_t
fd
=
taosCreateSocketWithTimeout
(
TRANS_CONN_TIMEOUT
*
4
);
if
(
fd
==
-
1
)
{
tGError
(
"%s conn %p failed to create socket, reason:%s"
,
transLabel
(
pTransInst
),
conn
,
...
...
@@ -1735,6 +1768,19 @@ static void cliAsyncCb(uv_async_t* handle) {
QUEUE_MOVE
(
&
item
->
qmsg
,
&
wq
);
taosThreadMutexUnlock
(
&
item
->
mtx
);
void
*
pIter
=
taosHashIterate
(
pThrd
->
msgCount
,
NULL
);
while
(
pIter
!=
NULL
)
{
int
*
count
=
pIter
;
size_t
len
=
0
;
char
*
key
=
taosHashGetKey
(
pIter
,
&
len
);
if
(
*
count
!=
0
)
{
tDebug
(
"key: %s count: %d"
,
key
,
*
count
);
}
pIter
=
taosHashIterate
(
pThrd
->
msgCount
,
pIter
);
}
tDebug
(
"all conn count: %d"
,
pThrd
->
newConnCount
);
int8_t
supportBatch
=
pTransInst
->
supportBatch
;
if
(
supportBatch
==
0
)
{
cliNoBatchDealReq
(
&
wq
,
pThrd
);
...
...
@@ -1969,6 +2015,9 @@ static SCliThrd* createThrdObj(void* trans) {
pThrd
->
batchCache
=
taosHashInit
(
8
,
taosGetDefaultHashFunction
(
TSDB_DATA_TYPE_BINARY
),
true
,
HASH_NO_LOCK
);
pThrd
->
quit
=
false
;
pThrd
->
newConnCount
=
0
;
pThrd
->
msgCount
=
taosHashInit
(
8
,
taosGetDefaultHashFunction
(
TSDB_DATA_TYPE_BINARY
),
true
,
HASH_NO_LOCK
);
return
pThrd
;
}
static
void
destroyThrdObj
(
SCliThrd
*
pThrd
)
{
...
...
@@ -2316,6 +2365,19 @@ int cliAppCb(SCliConn* pConn, STransMsg* pResp, SCliMsg* pMsg) {
}
}
if
((
pResp
->
msgType
-
1
>
TDMT_VND_TMQ_MSG
&&
pResp
->
msgType
-
1
<
TDMT_VND_TMQ_MAX_MSG
)
||
(
pResp
->
msgType
-
1
>
TDMT_MND_MSG
&&
pResp
->
msgType
-
1
<
TDMT_MND_MAX_MSG
))
{
char
buf
[
128
]
=
{
0
};
sprintf
(
buf
,
"%s"
,
TMSG_INFO
(
pResp
->
msgType
-
1
));
int
*
count
=
taosHashGet
(
pThrd
->
msgCount
,
buf
,
sizeof
(
buf
));
if
(
NULL
==
0
)
{
int
localCount
=
0
;
taosHashPut
(
pThrd
->
msgCount
,
buf
,
sizeof
(
buf
),
&
localCount
,
sizeof
(
localCount
));
}
else
{
int
localCount
=
*
count
-
1
;
taosHashPut
(
pThrd
->
msgCount
,
buf
,
sizeof
(
buf
),
&
localCount
,
sizeof
(
localCount
));
}
}
if
(
pCtx
->
pSem
!=
NULL
)
{
tGTrace
(
"%s conn %p(sync) handle resp"
,
CONN_GET_INST_LABEL
(
pConn
),
pConn
);
if
(
pCtx
->
pRsp
==
NULL
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录