如何从核心转储文件中识别导致崩溃的完整命令
How to identify the full command that caused the crash from the core dump file
使用 gdb 从核心转储文件中识别完整命令时出现问题 崩溃的命令本身可能很长
即
myCommand -f log/SlaRunTimeReport.rep -I input/myFile.txt -t output/myFile.txt
但是当使用 gdb 识别位置"核心生成者"中的命令时
即通过执行
gdb -c core.56536
输出:
GNU gdb (GDB) Red Hat Enterprise Linux 7.10-20.el7
….
Core was generated by `myCommand -f log/SlaRunTimeReport.rep -I
input/myFile.t'.
可以看到完整的命令(可执行文件+参数(被切在中间
‘myCommand -f log/SlaRunTimeReport.rep -I input/myFile.t'
在另外使用字符串命令时,也无助于识别完整命令
strings core.56536 | grep PMRunTimeReport
输出:
myCommand
myCommand -f log/SlaRunTimeReport.rep -I input/myFile.t
有没有办法从核心转储文件中获取导致失败的完整命令
提前致谢
有没有办法从核心转储文件中获取导致失败的完整命令
有多种方法,但运行strings
是错误的方法。
如果您使用调试信息构建了程序,您应该能够简单地执行up
命令直到到达main
,然后检查argv[0]
到argv[argc-1]
。
如果您的main
不是使用调试信息构建的,或者它不使用argc
和argv
,您应该能够从__libc_argc
和__libc_argv
变量中恢复该信息。例:
$ ./a.out foo bar baz $(python -c 'print "a" * 500')
Aborted (core dumped)
$ gdb -q ./a.out core
Core was generated by `./a.out foo bar baz aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.
注意,"生成者"被截断了——它来自struct prpsinfo
内部的固定长度数组,保存在core
NT_PRPSINFO
ELF笔记中。
Program terminated with signal SIGABRT, Aborted.
#0 0x00007fab38cfcf2b in raise () from /lib64/libc.so.6
Missing separate debuginfos, use: dnf debuginfo-install glibc-2.27-15.fc28.x86_64
(gdb) p (int)__libc_argc
$1 = 5
(gdb) p ((char**)__libc_argv)[0]@5
$2 = {0x7ffede43289f "./a.out", 0x7ffede4328a7 "foo", 0x7ffede4328ab "bar",
0x7ffede4328af "baz",
0x7ffede4328b3 'a' <repeats 200 times>...}
最後一行實際上是一個謊言——我們知道'a'
重複了500次。
我们可以这样修复它:
(gdb) set print elem 0
(gdb) p ((char**)__libc_argv)[0]@5
$3 = {0x7ffede43289f "./a.out", 0x7ffede4328a7 "foo", 0x7ffede4328ab "bar",
0x7ffede4328af "baz",
0x7ffede4328b3 'a' <repeats 500 times>}
瞧:我们现在有了完整的命令。
最后,如果您安装了 GLIBC 的调试信息,您只需查看__libc_start_main
(称为您的main
(:
(gdb) set backtrace past-main
(gdb) bt
#0 __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:50
#1 0x00007fab38ce7561 in __GI_abort () at abort.c:79
#2 0x00000000004004ef in main () at foo.c:3
#3 0x00007fab38ce918b in __libc_start_main (main=0x4004e6 <main>, argc=5, argv=0x7ffede431118,
init=<optimized out>, fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7ffede431108)
at ../csu/libc-start.c:308
#4 0x000000000040042a in _start ()
在这里,您可以清楚地看到第 3 帧中的argc
和argv
,并且可以像这样检查该argv
:
(gdb) fr 3
#3 0x00007fab38ce918b in __libc_start_main (main=0x4004e6 <main>, argc=5, argv=0x7ffede431118,
init=<optimized out>, fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7ffede431108)
at ../csu/libc-start.c:308
308 result = main (argc, argv, __environ MAIN_AUXVEC_PARAM);
(gdb) p argv[0]@5
$1 = {0x7ffede43289f "./a.out", 0x7ffede4328a7 "foo", 0x7ffede4328ab "bar",
0x7ffede4328af "baz",
0x7ffede4328b3 'a' <repeats 500 times>}
相关文章:
- 当回溯以零开始时,如何调试崩溃
- 从命令行c++发送文本文件名
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 内联映射初始化的动态atexit析构函数崩溃
- 执行函数时导致崩溃的变量
- 程序崩溃并显示"std::out_of_range"错误
- 使用QProcess执行命令,并将结果存储在QStringList中
- 数组长度,为什么从命令行获取时不能使用它?
- 如果调用 RtlSetProcessIsCritical,将使用 lstrcmpW 将命令行与值进行比较将使程序崩溃
- 如何从核心转储文件中识别导致崩溃的完整命令
- C++ - 代码在Visual Studio中完美运行,但命令行中的.exe不断崩溃
- VS 2005-命令行程序崩溃
- MFC C++-在没有命令的ProcessShellCommand()上崩溃
- Boost程序选项-解析命令行时崩溃
- 当从Xcode运行时,C++程序在main之前崩溃(但从命令行可以)
- 为什么我的命令行参数处理崩溃我的程序
- QT exec()命令崩溃
- 为什么这个c++程序在多个文件上通过命令提示符运行时会崩溃,而在单个文件上运行时却不会