Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
84772d1e
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
提交
84772d1e
编写于
7月 01, 2021
作者:
J
Jun Li
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add mutext protection for stop flag
上级
45289aef
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
18 addition
and
2 deletion
+18
-2
src/wal/src/walMgmt.c
src/wal/src/walMgmt.c
+18
-2
未找到文件。
src/wal/src/walMgmt.c
浏览文件 @
84772d1e
...
@@ -36,9 +36,16 @@ static int32_t walInitObj(SWal *pWal);
...
@@ -36,9 +36,16 @@ static int32_t walInitObj(SWal *pWal);
static
void
walFreeObj
(
void
*
pWal
);
static
void
walFreeObj
(
void
*
pWal
);
int32_t
walInit
()
{
int32_t
walInit
()
{
int32_t
code
=
0
;
tsWal
.
refId
=
taosOpenRef
(
TSDB_MIN_VNODES
,
walFreeObj
);
tsWal
.
refId
=
taosOpenRef
(
TSDB_MIN_VNODES
,
walFreeObj
);
int32_t
code
=
walCreateThread
();
code
=
pthread_mutex_init
(
&
tsWal
.
mutex
,
NULL
);
if
(
code
)
{
wError
(
"failed to init wal mutex since %s"
,
tstrerror
(
code
));
return
code
;
}
code
=
walCreateThread
();
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
wError
(
"failed to init wal module since %s"
,
tstrerror
(
code
));
wError
(
"failed to init wal module since %s"
,
tstrerror
(
code
));
return
code
;
return
code
;
...
@@ -51,6 +58,7 @@ int32_t walInit() {
...
@@ -51,6 +58,7 @@ int32_t walInit() {
void
walCleanUp
()
{
void
walCleanUp
()
{
walStopThread
();
walStopThread
();
taosCloseRef
(
tsWal
.
refId
);
taosCloseRef
(
tsWal
.
refId
);
pthread_mutex_destroy
(
&
tsWal
.
mutex
);
wInfo
(
"wal module is cleaned up"
);
wInfo
(
"wal module is cleaned up"
);
}
}
...
@@ -183,10 +191,15 @@ static void walFsyncAll() {
...
@@ -183,10 +191,15 @@ static void walFsyncAll() {
}
}
static
void
*
walThreadFunc
(
void
*
param
)
{
static
void
*
walThreadFunc
(
void
*
param
)
{
int
stop
=
0
;
while
(
1
)
{
while
(
1
)
{
walUpdateSeq
();
walUpdateSeq
();
walFsyncAll
();
walFsyncAll
();
if
(
tsWal
.
stop
)
break
;
pthread_mutex_lock
(
&
tsWal
.
mutex
);
stop
=
tsWal
.
stop
;
pthread_mutex_unlock
(
&
tsWal
.
mutex
);
if
(
stop
)
break
;
}
}
return
NULL
;
return
NULL
;
...
@@ -209,7 +222,10 @@ static int32_t walCreateThread() {
...
@@ -209,7 +222,10 @@ static int32_t walCreateThread() {
}
}
static
void
walStopThread
()
{
static
void
walStopThread
()
{
pthread_mutex_lock
(
&
tsWal
.
mutex
);
tsWal
.
stop
=
1
;
tsWal
.
stop
=
1
;
pthread_mutex_unlock
(
&
tsWal
.
mutex
);
if
(
taosCheckPthreadValid
(
tsWal
.
thread
))
{
if
(
taosCheckPthreadValid
(
tsWal
.
thread
))
{
pthread_join
(
tsWal
.
thread
,
NULL
);
pthread_join
(
tsWal
.
thread
,
NULL
);
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录