Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
e5614964
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看板
提交
e5614964
编写于
3月 25, 2022
作者:
D
dapan1121
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'feature/scheduler' of github.com:taosdata/TDengine into feature/scheduler
上级
64f0fe2f
5cc8da59
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
21 addition
and
19 deletion
+21
-19
source/libs/transport/src/transCli.c
source/libs/transport/src/transCli.c
+14
-14
source/libs/transport/src/transSrv.c
source/libs/transport/src/transSrv.c
+7
-5
未找到文件。
source/libs/transport/src/transCli.c
浏览文件 @
e5614964
...
@@ -159,7 +159,7 @@ static void destroyThrdObj(SCliThrdObj* pThrd);
...
@@ -159,7 +159,7 @@ static void destroyThrdObj(SCliThrdObj* pThrd);
int i = 0, sz = transQueueSize(&conn->cliMsgs); \
int i = 0, sz = transQueueSize(&conn->cliMsgs); \
for (; i < sz; i++) { \
for (; i < sz; i++) { \
pMsg = transQueueGet(&conn->cliMsgs, i); \
pMsg = transQueueGet(&conn->cliMsgs, i); \
if (pMsg != NULL && (uint64_t)pMsg->ctx->ahandle == ahandle) { \
if (pMsg != NULL &&
pMsg->ctx != NULL &&
(uint64_t)pMsg->ctx->ahandle == ahandle) { \
break; \
break; \
} \
} \
} \
} \
...
...
source/libs/transport/src/transSrv.c
浏览文件 @
e5614964
...
@@ -644,6 +644,7 @@ static void uvDestroyConn(uv_handle_t* handle) {
...
@@ -644,6 +644,7 @@ static void uvDestroyConn(uv_handle_t* handle) {
// free(conn);
// free(conn);
if
(
thrd
->
quit
&&
QUEUE_IS_EMPTY
(
&
thrd
->
conn
))
{
if
(
thrd
->
quit
&&
QUEUE_IS_EMPTY
(
&
thrd
->
conn
))
{
tTrace
(
"work thread quit"
);
uv_loop_close
(
thrd
->
loop
);
uv_loop_close
(
thrd
->
loop
);
uv_stop
(
thrd
->
loop
);
uv_stop
(
thrd
->
loop
);
}
}
...
@@ -705,12 +706,12 @@ End:
...
@@ -705,12 +706,12 @@ End:
return
NULL
;
return
NULL
;
}
}
void
uvHandleQuit
(
SSrvMsg
*
msg
,
SWorkThrdObj
*
thrd
)
{
void
uvHandleQuit
(
SSrvMsg
*
msg
,
SWorkThrdObj
*
thrd
)
{
thrd
->
quit
=
true
;
if
(
QUEUE_IS_EMPTY
(
&
thrd
->
conn
))
{
if
(
QUEUE_IS_EMPTY
(
&
thrd
->
conn
))
{
uv_loop_close
(
thrd
->
loop
);
uv_loop_close
(
thrd
->
loop
);
uv_stop
(
thrd
->
loop
);
uv_stop
(
thrd
->
loop
);
}
else
{
}
else
{
destroyAllConn
(
thrd
);
destroyAllConn
(
thrd
);
thrd
->
quit
=
true
;
}
}
free
(
msg
);
free
(
msg
);
}
}
...
@@ -773,15 +774,16 @@ void sendQuitToWorkThrd(SWorkThrdObj* pThrd) {
...
@@ -773,15 +774,16 @@ void sendQuitToWorkThrd(SWorkThrdObj* pThrd) {
void
transCloseServer
(
void
*
arg
)
{
void
transCloseServer
(
void
*
arg
)
{
// impl later
// impl later
SServerObj
*
srv
=
arg
;
SServerObj
*
srv
=
arg
;
for
(
int
i
=
0
;
i
<
srv
->
numOfThreads
;
i
++
)
{
sendQuitToWorkThrd
(
srv
->
pThreadObj
[
i
]);
destroyWorkThrd
(
srv
->
pThreadObj
[
i
]);
}
tDebug
(
"send quit msg to accept thread"
);
tDebug
(
"send quit msg to accept thread"
);
uv_async_send
(
srv
->
pAcceptAsync
);
uv_async_send
(
srv
->
pAcceptAsync
);
taosThreadJoin
(
srv
->
thread
,
NULL
);
taosThreadJoin
(
srv
->
thread
,
NULL
);
for
(
int
i
=
0
;
i
<
srv
->
numOfThreads
;
i
++
)
{
sendQuitToWorkThrd
(
srv
->
pThreadObj
[
i
]);
destroyWorkThrd
(
srv
->
pThreadObj
[
i
]);
}
free
(
srv
->
pThreadObj
);
free
(
srv
->
pThreadObj
);
free
(
srv
->
pAcceptAsync
);
free
(
srv
->
pAcceptAsync
);
free
(
srv
->
loop
);
free
(
srv
->
loop
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录