Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
a3447c5d
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
a3447c5d
编写于
10月 24, 2022
作者:
dengyihao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
avoid invalid read/write
上级
309fecba
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
16 addition
and
3 deletion
+16
-3
source/libs/transport/src/transSvr.c
source/libs/transport/src/transSvr.c
+16
-3
未找到文件。
source/libs/transport/src/transSvr.c
浏览文件 @
a3447c5d
...
@@ -374,7 +374,11 @@ static void uvOnPipeWriteCb(uv_write_t* req, int status) {
...
@@ -374,7 +374,11 @@ static void uvOnPipeWriteCb(uv_write_t* req, int status) {
}
else
{
}
else
{
tError
(
"fail to dispatch conn to work thread"
);
tError
(
"fail to dispatch conn to work thread"
);
}
}
uv_close
((
uv_handle_t
*
)
req
->
data
,
uvFreeCb
);
if
(
!
uv_is_closing
((
uv_handle_t
*
)
req
->
data
))
{
uv_close
((
uv_handle_t
*
)
req
->
data
,
uvFreeCb
);
}
else
{
taosMemoryFree
(
req
->
data
);
}
taosMemoryFree
(
req
);
taosMemoryFree
(
req
);
}
}
...
@@ -668,7 +672,11 @@ void uvOnAcceptCb(uv_stream_t* stream, int status) {
...
@@ -668,7 +672,11 @@ void uvOnAcceptCb(uv_stream_t* stream, int status) {
uv_write2
(
wr
,
(
uv_stream_t
*
)
&
(
pObj
->
pipe
[
pObj
->
workerIdx
][
0
]),
&
buf
,
1
,
(
uv_stream_t
*
)
cli
,
uvOnPipeWriteCb
);
uv_write2
(
wr
,
(
uv_stream_t
*
)
&
(
pObj
->
pipe
[
pObj
->
workerIdx
][
0
]),
&
buf
,
1
,
(
uv_stream_t
*
)
cli
,
uvOnPipeWriteCb
);
}
else
{
}
else
{
uv_close
((
uv_handle_t
*
)
cli
,
NULL
);
if
(
!
uv_is_closing
((
uv_handle_t
*
)
cli
))
{
uv_close
((
uv_handle_t
*
)
cli
,
NULL
);
}
else
{
taosMemoryFree
(
cli
);
}
}
}
}
}
void
uvOnConnectionCb
(
uv_stream_t
*
q
,
ssize_t
nread
,
const
uv_buf_t
*
buf
)
{
void
uvOnConnectionCb
(
uv_stream_t
*
q
,
ssize_t
nread
,
const
uv_buf_t
*
buf
)
{
...
@@ -681,7 +689,6 @@ void uvOnConnectionCb(uv_stream_t* q, ssize_t nread, const uv_buf_t* buf) {
...
@@ -681,7 +689,6 @@ void uvOnConnectionCb(uv_stream_t* q, ssize_t nread, const uv_buf_t* buf) {
tWarn
(
"failed to create connect:%p"
,
q
);
tWarn
(
"failed to create connect:%p"
,
q
);
taosMemoryFree
(
buf
->
base
);
taosMemoryFree
(
buf
->
base
);
uv_close
((
uv_handle_t
*
)
q
,
NULL
);
uv_close
((
uv_handle_t
*
)
q
,
NULL
);
// taosMemoryFree(q);
return
;
return
;
}
}
// free memory allocated by
// free memory allocated by
...
@@ -972,6 +979,7 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
...
@@ -972,6 +979,7 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
snprintf
(
pipeName
,
sizeof
(
pipeName
),
"%s%spipe.trans.rpc.%08d-%"
PRIu64
,
tsTempDir
,
TD_DIRSEP
,
taosSafeRand
(),
snprintf
(
pipeName
,
sizeof
(
pipeName
),
"%s%spipe.trans.rpc.%08d-%"
PRIu64
,
tsTempDir
,
TD_DIRSEP
,
taosSafeRand
(),
taosGetSelfPthreadId
());
taosGetSelfPthreadId
());
#endif
#endif
ret
=
uv_pipe_bind
(
&
srv
->
pipeListen
,
pipeName
);
ret
=
uv_pipe_bind
(
&
srv
->
pipeListen
,
pipeName
);
if
(
ret
!=
0
)
{
if
(
ret
!=
0
)
{
tError
(
"failed to bind pipe, errmsg: %s"
,
uv_err_name
(
ret
));
tError
(
"failed to bind pipe, errmsg: %s"
,
uv_err_name
(
ret
));
...
@@ -997,6 +1005,7 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
...
@@ -997,6 +1005,7 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
if
(
false
==
addHandleToWorkloop
(
thrd
,
pipeName
))
{
if
(
false
==
addHandleToWorkloop
(
thrd
,
pipeName
))
{
goto
End
;
goto
End
;
}
}
int
err
=
taosThreadCreate
(
&
(
thrd
->
thread
),
NULL
,
transWorkerThread
,
(
void
*
)(
thrd
));
int
err
=
taosThreadCreate
(
&
(
thrd
->
thread
),
NULL
,
transWorkerThread
,
(
void
*
)(
thrd
));
if
(
err
==
0
)
{
if
(
err
==
0
)
{
tDebug
(
"success to create worker-thread:%d"
,
i
);
tDebug
(
"success to create worker-thread:%d"
,
i
);
...
@@ -1006,14 +1015,17 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
...
@@ -1006,14 +1015,17 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
goto
End
;
goto
End
;
}
}
}
}
if
(
false
==
taosValidIpAndPort
(
srv
->
ip
,
srv
->
port
))
{
if
(
false
==
taosValidIpAndPort
(
srv
->
ip
,
srv
->
port
))
{
terrno
=
TAOS_SYSTEM_ERROR
(
errno
);
terrno
=
TAOS_SYSTEM_ERROR
(
errno
);
tError
(
"invalid ip/port, %d:%d, reason:%s"
,
srv
->
ip
,
srv
->
port
,
terrstr
());
tError
(
"invalid ip/port, %d:%d, reason:%s"
,
srv
->
ip
,
srv
->
port
,
terrstr
());
goto
End
;
goto
End
;
}
}
if
(
false
==
addHandleToAcceptloop
(
srv
))
{
if
(
false
==
addHandleToAcceptloop
(
srv
))
{
goto
End
;
goto
End
;
}
}
int
err
=
taosThreadCreate
(
&
srv
->
thread
,
NULL
,
transAcceptThread
,
(
void
*
)
srv
);
int
err
=
taosThreadCreate
(
&
srv
->
thread
,
NULL
,
transAcceptThread
,
(
void
*
)
srv
);
if
(
err
==
0
)
{
if
(
err
==
0
)
{
tDebug
(
"success to create accept-thread"
);
tDebug
(
"success to create accept-thread"
);
...
@@ -1022,6 +1034,7 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
...
@@ -1022,6 +1034,7 @@ void* transInitServer(uint32_t ip, uint32_t port, char* label, int numOfThreads,
goto
End
;
goto
End
;
// clear all resource later
// clear all resource later
}
}
srv
->
inited
=
true
;
srv
->
inited
=
true
;
return
srv
;
return
srv
;
End:
End:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录