我有一个进程运行在一个非常弱的Linux嵌入式设备上,它无法在其自身上运行gdb / gdb服务器。我让它多次从共享库中触发一个函数X(还有其他一些进程同时调用它的频率要低得多),它通常在共享库中挂起1天或半天之后。如何调试:
我试过的是:
阻塞了。
发布于 2019-09-20 02:27:31
gdb附带了一个名为gcore的程序,它将从正在运行的过程中生成一个核心文件。
现在许多系统默认禁用核心文件( shell中的ulimit -c将显示0)。使用ulimit -c unlimited shell命令,然后在同一个shell中运行您的进程(这些限制是从父进程继承的)。如果您以其他方式启动您的进程,而不是直接从shell开始,您将需要了解如何将它们设置在那里。例如,系统单元文件中的LimitCORE= )。
一旦您的进程进入坏状态,在其进程ID上运行gcore,然后您可以将它复制到您的工作站并将其加载到gdb (gdb <executable> <core-file>)中。然后,可以查看堆栈跟踪和核心转储开始时的其他状态。
https://stackoverflow.com/questions/58020708
复制相似问题