Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
44985039
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
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看板
未验证
提交
44985039
编写于
12月 03, 2021
作者:
S
Shengliang Guan
提交者:
GitHub
12月 03, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #8729 from haoyifan/dnode_alloc_fix
Handle memory allocation failure when open vnode
上级
e479bafa
d8373730
变更
4
展开全部
隐藏空白更改
内联
并排
Showing
4 changed file
with
421 addition
and
402 deletion
+421
-402
src/dnode/src/dnodeMain.c
src/dnode/src/dnodeMain.c
+6
-6
src/dnode/src/dnodeVnodes.c
src/dnode/src/dnodeVnodes.c
+21
-4
src/inc/taoserror.h
src/inc/taoserror.h
+392
-391
src/util/src/terror.c
src/util/src/terror.c
+2
-1
未找到文件。
src/dnode/src/dnodeMain.c
浏览文件 @
44985039
...
...
@@ -78,14 +78,14 @@ static SStep tsDnodeSteps[] = {
{
"dnode-vmgmt"
,
dnodeInitVMgmt
,
dnodeCleanupVMgmt
},
{
"dnode-mread"
,
dnodeInitMRead
,
NULL
},
{
"dnode-mwrite"
,
dnodeInitMWrite
,
NULL
},
{
"dnode-mpeer"
,
dnodeInitMPeer
,
NULL
},
{
"dnode-mpeer"
,
dnodeInitMPeer
,
NULL
},
{
"dnode-client"
,
dnodeInitClient
,
dnodeCleanupClient
},
{
"dnode-server"
,
dnodeInitServer
,
dnodeCleanupServer
},
{
"dnode-vnodes"
,
dnodeInitVnodes
,
dnodeCleanupVnodes
},
{
"dnode-modules"
,
dnodeInitModules
,
dnodeCleanupModules
},
{
"dnode-mread"
,
NULL
,
dnodeCleanupMRead
},
{
"dnode-mwrite"
,
NULL
,
dnodeCleanupMWrite
},
{
"dnode-mpeer"
,
NULL
,
dnodeCleanupMPeer
},
{
"dnode-mpeer"
,
NULL
,
dnodeCleanupMPeer
},
{
"dnode-shell"
,
dnodeInitShell
,
dnodeCleanupShell
},
{
"dnode-statustmr"
,
dnodeInitStatusTimer
,
dnodeCleanupStatusTimer
},
{
"dnode-telemetry"
,
dnodeInitTelemetry
,
dnodeCleanupTelemetry
},
...
...
@@ -121,7 +121,7 @@ static int dnodeCreateDir(const char *dir) {
if
(
mkdir
(
dir
,
0755
)
!=
0
&&
errno
!=
EEXIST
)
{
return
-
1
;
}
return
0
;
}
...
...
@@ -263,8 +263,8 @@ static int32_t dnodeInitStorage() {
if
(
tsDiskCfgNum
==
1
&&
dnodeCreateDir
(
tsDataDir
)
<
0
)
{
dError
(
"failed to create dir: %s, reason: %s"
,
tsDataDir
,
strerror
(
errno
));
return
-
1
;
}
}
if
(
tfsInit
(
tsDiskCfg
,
tsDiskCfgNum
)
<
0
)
{
dError
(
"failed to init TFS since %s"
,
tstrerror
(
terrno
));
return
-
1
;
...
...
@@ -296,7 +296,7 @@ static int32_t dnodeInitStorage() {
if
(
dnodeCreateDir
(
tsMnodeDir
)
<
0
)
{
dError
(
"failed to create dir: %s, reason: %s"
,
tsMnodeDir
,
strerror
(
errno
));
return
-
1
;
}
}
if
(
dnodeCreateDir
(
tsDnodeDir
)
<
0
)
{
dError
(
"failed to create dir: %s, reason: %s"
,
tsDnodeDir
,
strerror
(
errno
));
...
...
src/dnode/src/dnodeVnodes.c
浏览文件 @
44985039
...
...
@@ -127,9 +127,20 @@ int32_t dnodeInitVnodes() {
int32_t
threadNum
=
tsNumOfCores
;
int32_t
vnodesPerThread
=
numOfVnodes
/
threadNum
+
1
;
SOpenVnodeThread
*
threads
=
calloc
(
threadNum
,
sizeof
(
SOpenVnodeThread
));
if
(
threads
==
NULL
)
{
return
TSDB_CODE_DND_OUT_OF_MEMORY
;
}
for
(
int32_t
t
=
0
;
t
<
threadNum
;
++
t
)
{
threads
[
t
].
threadIndex
=
t
;
threads
[
t
].
vnodeList
=
calloc
(
vnodesPerThread
,
sizeof
(
int32_t
));
if
(
threads
[
t
].
vnodeList
==
NULL
)
{
dError
(
"vnodeList allocation failed"
);
status
=
TSDB_CODE_DND_OUT_OF_MEMORY
;
goto
DNODE_INIT_VNODES_OUT
;
}
}
for
(
int32_t
v
=
0
;
v
<
numOfVnodes
;
++
v
)
{
...
...
@@ -163,18 +174,24 @@ int32_t dnodeInitVnodes() {
}
openVnodes
+=
pThread
->
opened
;
failedVnodes
+=
pThread
->
failed
;
free
(
pThread
->
vnodeList
);
}
free
(
threads
);
dInfo
(
"there are total vnodes:%d, opened:%d"
,
numOfVnodes
,
openVnodes
);
if
(
failedVnodes
!=
0
)
{
dError
(
"there are total vnodes:%d, failed:%d"
,
numOfVnodes
,
failedVnodes
);
return
-
1
;
status
=
TSDB_CODE_DND_VNODE_OPEN_FAILED
;
}
return
TSDB_CODE_SUCCESS
;
DNODE_INIT_VNODES_OUT:
for
(
int32_t
t
=
0
;
t
<
threadNum
;
++
t
)
{
SOpenVnodeThread
*
pThread
=
&
threads
[
t
];
free
(
pThread
->
vnodeList
);
}
free
(
threads
);
return
status
;
}
void
dnodeCleanupVnodes
()
{
...
...
src/inc/taoserror.h
浏览文件 @
44985039
此差异已折叠。
点击以展开。
src/util/src/terror.c
浏览文件 @
44985039
...
...
@@ -16,7 +16,7 @@
#include "os.h"
#define TAOS_ERROR_C
typedef
struct
{
int32_t
val
;
const
char
*
str
;
...
...
@@ -232,6 +232,7 @@ TAOS_DEFINE_ERROR(TSDB_CODE_DND_INVALID_MSG_LEN, "Invalid message lengt
TAOS_DEFINE_ERROR
(
TSDB_CODE_DND_ACTION_IN_PROGRESS
,
"Action in progress"
)
TAOS_DEFINE_ERROR
(
TSDB_CODE_DND_TOO_MANY_VNODES
,
"Too many vnode directories"
)
TAOS_DEFINE_ERROR
(
TSDB_CODE_DND_EXITING
,
"Dnode is exiting"
)
TAOS_DEFINE_ERROR
(
TSDB_CODE_DND_VNODE_OPEN_FAILED
,
"Vnode open failed"
)
// vnode
TAOS_DEFINE_ERROR
(
TSDB_CODE_VND_ACTION_IN_PROGRESS
,
"Action in progress"
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录