在平时编码中有时候会遗漏对指针等内存操作的异常保护,而当设备访问异常内存空间时,操作系统会直接杀死改进程。当代码流程较多时,排查这类问题就比较痛苦,索性linux提供了coredump,改文件会保存进程被kill前调用的栈信息,根据这些信息我们可以快速的定位故障点。本文将介绍在openwrt中如果根据coredump来快速定位程序崩溃问题。
编写一个内存使用异常的程序:
编写一个helloworld程序,改程序直接访问空指针,改操作肯定会导致进程崩溃。
![7544f89b64e7be76e5538755e2b74b3f.png](https://img-blog.csdnimg.cn/img_convert/7544f89b64e7be76e5538755e2b74b3f.png)
开启coredump功能:
openwrt中一般默认没有打开coredump功能,所以我们要先开启改功能,按照下面的配置开启之后,如果进程异常崩溃了,则会在/tmp目录下生成coredump文件。
ulimit -c unlimited
echo "/tmp/core-%e-%p-%t" > /proc/sys/kernel/core_pattern
执行helloworld程序:
从下图可以看出,我们已经生成了coredump文件。