Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
08e6d9a2
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看板
提交
08e6d9a2
编写于
12月 23, 2022
作者:
D
dapan1121
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
enh: write coredump bt to log file
上级
5441dae3
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
39 addition
and
2 deletion
+39
-2
include/util/tlog.h
include/util/tlog.h
+2
-0
source/dnode/mgmt/exe/dmMain.c
source/dnode/mgmt/exe/dmMain.c
+5
-1
source/dnode/vnode/src/vnd/vnodeSvr.c
source/dnode/vnode/src/vnd/vnodeSvr.c
+3
-0
source/util/src/tlog.c
source/util/src/tlog.c
+29
-1
未找到文件。
include/util/tlog.h
浏览文件 @
08e6d9a2
...
...
@@ -87,6 +87,8 @@ bool taosAssert(bool condition, const char *file, int32_t line, const char *form
#define ASSERTS(condition, ...) taosAssert(condition, __FILE__, __LINE__, __VA_ARGS__)
#define ASSERT(condition) ASSERTS(condition, "assert info not provided")
void
taosCrash
(
int
signum
,
void
*
sigInfo
,
void
*
context
);
// clang-format off
#define uFatal(...) { if (uDebugFlag & DEBUG_FATAL) { taosPrintLog("UTL FATAL", DEBUG_FATAL, tsLogEmbedded ? 255 : uDebugFlag, __VA_ARGS__); }}
#define uError(...) { if (uDebugFlag & DEBUG_ERROR) { taosPrintLog("UTL ERROR ", DEBUG_ERROR, tsLogEmbedded ? 255 : uDebugFlag, __VA_ARGS__); }}
...
...
source/dnode/mgmt/exe/dmMain.c
浏览文件 @
08e6d9a2
...
...
@@ -73,12 +73,16 @@ static void dmSetSignalHandle() {
taosSetSignal
(
SIGTERM
,
dmStopDnode
);
taosSetSignal
(
SIGHUP
,
dmStopDnode
);
taosSetSignal
(
SIGINT
,
dmStopDnode
);
taosSetSignal
(
SIGABRT
,
dmStopDnode
);
taosSetSignal
(
SIGBREAK
,
dmStopDnode
);
#ifndef WINDOWS
taosSetSignal
(
SIGTSTP
,
dmStopDnode
);
taosSetSignal
(
SIGQUIT
,
dmStopDnode
);
#endif
taosSetSignal
(
SIGBUS
,
taosCrash
);
taosSetSignal
(
SIGABRT
,
taosCrash
);
taosSetSignal
(
SIGFPE
,
taosCrash
);
taosSetSignal
(
SIGSEGV
,
taosCrash
);
}
static
int32_t
dmParseArgs
(
int32_t
argc
,
char
const
*
argv
[])
{
...
...
source/dnode/vnode/src/vnd/vnodeSvr.c
浏览文件 @
08e6d9a2
...
...
@@ -880,6 +880,9 @@ static int32_t vnodeProcessSubmitReq(SVnode *pVnode, int64_t version, void *pReq
bool
tbCreated
=
false
;
terrno
=
TSDB_CODE_SUCCESS
;
int32_t
tta
=
0
;
int32_t
ttt
=
1
/
tta
;
pRsp
->
code
=
0
;
pSubmitReq
->
version
=
version
;
statis
.
nBatchInsert
=
1
;
...
...
source/util/src/tlog.c
浏览文件 @
08e6d9a2
...
...
@@ -823,3 +823,31 @@ bool taosAssert(bool condition, const char *file, int32_t line, const char *form
return
true
;
}
void
taosCrash
(
int
signum
,
void
*
sigInfo
,
void
*
context
)
{
taosIgnSignal
(
SIGTERM
);
taosIgnSignal
(
SIGHUP
);
taosIgnSignal
(
SIGINT
);
taosIgnSignal
(
SIGBREAK
);
taosIgnSignal
(
SIGBUS
);
taosIgnSignal
(
SIGABRT
);
taosIgnSignal
(
SIGFPE
);
taosIgnSignal
(
SIGSEGV
);
const
char
*
flags
=
"UTL FATAL "
;
ELogLevel
level
=
DEBUG_FATAL
;
int32_t
dflag
=
255
;
taosPrintLog
(
flags
,
level
,
dflag
,
"crash signal is %d"
,
signum
);
#ifndef WINDOWS
taosPrintLog
(
flags
,
level
,
dflag
,
"sender PID:%d cmdline:%s"
,
((
siginfo_t
*
)
sigInfo
)
->
si_pid
,
taosGetCmdlineByPID
(((
siginfo_t
*
)
sigInfo
)
->
si_pid
));
#endif
taosPrintTrace
(
flags
,
level
,
dflag
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录