- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
是否有可能使用 C/C++ 代码回溯子进程在 Linux 中崩溃的位置?我想要做的是:
这将使父进程在附加进程崩溃时表现得类似于调试器。您可以假设子进程是使用调试符号编译的,而父进程具有 root 权限。
实现此类功能的最简单方法是什么?
最佳答案
在 Linux 中使用作为 GNU C 库的一部分提供的 libSegFault
库要简单得多。在我的系统上,它安装在 /lib/x86_64-linux-gnu/libSegFault.so
中。
您需要做的就是将 SEGFAULT_SIGNALS
环境变量设置为 all
(这样您就可以捕获库支持的所有崩溃原因),可选 SEGFAULT_OUTPUT_NAME
指向写入堆栈跟踪的文件(默认为标准错误),LD_PRELOAD
指向段错误库。只要进程不修改这些环境变量,它们也适用于所有子进程。
例如,如果 ./yourprog
是 fork 一个崩溃的子程序的程序,并且您希望堆栈跟踪到 ./yourprog.stacktrace
,运行
SEGFAULT_SIGNALS=all \
SEGFAULT_OUTPUT_NAME=./yourprog.stacktrace \
LD_PRELOAD=/lib/x86_64-linux-gnu/libSegFault.so \
./yourprog
或全部在一行中,不带反斜杠 (\
)。
唯一的缺点是每次崩溃都会覆盖现有文件,因此您只能看到最新的文件。如果您安装了 /proc
,则故障转储包括崩溃时刻进程的回溯和内存映射。
如果你坚持要在自己的C程序中做,我建议你先看看libSegFault sources .
重点是,堆栈跟踪必须由进程本身转储; parent 无法访问它。为此,您可以使用例如将代码注入(inject)子进程。 LD_PRELOAD
环境变量(Linux 中的动态链接器控制变量之一)。 (请注意,堆栈跟踪等是在信号处理程序上下文中完成的,因此只能使用异步信号安全函数。)
例如,父进程可以创建一个管道,并在执行目标进程之前将其写入端移动到子进程中的特定描述符,您的助手预加载库路径在 LD_PRELOAD 中。
辅助预加载库插入signal()
、sigaction()
,可能还有sigprocmask()
、sigwait()
、sigwaitinfo()
、pthread_sigmask()
,以确保在传递此类信号时执行辅助库崩溃转储信号处理程序 (SIGSEGV
、SIGBUS
、SIGILL
,可能还有 SIGTRAP
)。信号处理程序执行堆栈转储(并打印/proc/PID/maps),然后将信号处理设置为默认值,并重新发出信号(使用 raise()
)。
本质上,它归结为与上述 libSegFault 相同的操作,除了使用您自己的 C 代码。
如果您不想向子进程注入(inject)代码,或者管理信号处理程序过于复杂,您可以使用ptrace。相反。
当 tracee 被信号(SIGKILL
除外)杀死时,接收信号的线程首先停止(“signal-delivery-stop”),所以在让子进程继续/死亡之前,跟踪器可以检查其堆栈(和被跟踪者的内存映射)。
在实践中,ptracing 更具侵入性,因为有许多事件会导致 tracees 线程停止。对于多线程进程,它也比 LD_PRELOAD 方法复杂得多,因为 ptrace 可以控制 tracee 中的各个线程;还有更多细节需要正确处理。
关于c - 如何使用 C 以编程方式回溯 fork 子项的崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52149094/
我正在尝试将 margin-left:20px 分配给表单内的所有 div,其类包含编辑,具有以下内容: form.edit > div { margin-left:20px; } 我的想法
我有这个 xpath: .//*[@id='some_id']/td//div 现在我想选择特定类型的 div 的任何子项,例如每个子项是标签或跨度。像这样的东西 .//*[@id='some_id'
我有一个包含包含用户信息的键列表的键,现在当我的表单加载时,我想将这些键作为数组获取。我该怎么做?我找到了获取计数的方法,但仍然不知道如何获取这些 key 。 最佳答案 您可以使用 Microsoft
关闭。这个问题需要更多 focused 。它目前不接受答案。 想要改进这个问题?更新问题,使其只关注 editing this post 的一个问题。 关闭 6 年前。 Improve this q
我正在通过一些在线教程来学习 AEM。根据教程,创建组件时,需要在 Allowed Parents 或 Allowed Children 中输入一些值。但是,我在窗口中看不到这样的选项。当我尝试创建组
我需要将 MDI 子窗体的创建集中到 Delphi (VCL) 中的一个独特过程中。这个想法是每次创建 MDI 子窗体时执行一些操作,无论其类型如何,即将其标题名称添加到列表中以访问该 MDI 子窗体
我试图在 TreeView 中获取所选节点的所有子节点,但遇到了一些问题。 以这个 TreeView 为例: 我想将所有子节点变为黄色突出显示的“文件夹”节点,这将是旁边有一条蓝线的子节点。 这是我尝
我在最小化我所有的 MDIChildren 时遇到了麻烦,遇到了 MDIChild to minimize not activated properly 我最小化所有 child 的代码是: proc
我使用下面的代码通过单击系统关闭按钮来关闭 MDI 子窗体,它工作正常: procedure Tfrm_main.FormClose(Sender: TObject; var Action: TC
仅当我指定对象的完整路径时,我才能通过指定特定子键来查找 Firebase 对象。这是为什么? 这有效 ref.child(`users/${user.uid}/watchlist/${key}`)
每当我单击工具栏菜单时,它每次都会显示新表单。我想阻止它一次又一次地显示相同的表单。在给出的代码中,form2 一次又一次地显示。我想停止它,以便它显示一次。 喜欢: private void new
我想知道是否有一种方法可以通过遍历父节点的 vector 来获取子节点中的数据。我有一个我计划经常更改的 XML 文件,因此我想避免对属性名称进行硬编码。因此,我想在我的子节点中提取数据而不使用 pt
假设我有以下 YAML 文件: - key1: value # and so on... key99: value key100: subkey1: value # an
我不是代码天才,而是行动脚本爱好者。 你能帮我吗? 我有一个函数,根据选择的对象,该函数将事件监听器调用已经在舞台上的一组“子项目”(我想在单击时重新使用具有更改参数的子项目,而不是创建多个实例和代码
我需要一些帮助来查询分层数据。这是一个简单的表,其中 parent_id 引用 id 并且对于根条目可能为 null。 create table edition ( id
我尝试获得一个简单的 GEF 编辑器。我有一个 GraphicalEditorWithPalette 来创建我的示例模型。我有一个覆盖 createFigure 和 getModelChildren
我正在尝试搜索其中包含子项(文本区域)的表格单元格。我努力了td.children.value,td.childNodes.value,td.firstChild.value,td.lastChild
我有一个 mdi 父 form 并且我在运行时通过以下代码将我的其他 form 作为 mdi 子窗体打开: private void MenuItem_Click(object sender, Eve
我在 Activity 中加载了一个 GridView,其中存在 fragment 。 GridView 本身并不位于 Fragment 中。我通过 BaseAdapter 创建了一个客户适配器,一切
我在导航 Controller 中有两个 child (根 child 和第二个 child )。我通常先去找根 child ,然后再去找第二个 child 。这允许我使用导航 Controller
我是一名优秀的程序员,十分优秀!