返回介绍

systemd-coredump 中文手册

发布于 2020-11-08 09:27:17 字数 4618 浏览 1091 评论 0 收藏 0

名称

systemd-coredump, systemd-coredump.socket, systemd-coredump@.service — 获取、保存、处理内存转储

大纲

/usr/lib/systemd/systemd-coredump

/usr/lib/systemd/systemd-coredump --backtrace

systemd-coredump@.service

systemd-coredump.socket

描述

systemd-coredump@.service 是一个系统服务,它能从操作系统内核中获取内存转储,并能对获取到的数据进行各种处理。该服务的功能实际由 systemd-coredump可执行程序实现,该程序被先后调用两次:第一次被操作系统内核作为内存转储处理器调用;第二次被 systemd-coredump@.service 服务调用,用于将获取到的数据写入文件或日志中。

当操作系统内核调用 systemd-coredump 来处理内存转储时,它将以特权模式运行,并连接到systemd-coredump.socket 单元创建的套接字上,接着再派生一个非特权模式的systemd-coredump@.service 实例来处理所获取的内存转储。可见,systemd-coredump.socketsystemd-coredump@.service是为了实现对内存转储进行统一管理而专门设置的辅助单元。

内存转储既可以保存到日志中,也可以保存到单独的文件中,以便于将来被例如gdb(1) 这样的工具做进一步的分析和处理。

默认情况下,systemd-coredump 会把内存转储事件以及可能存在的回溯(backtrace)保存到日志中,同时把内存转储自身的数据(内存镜像)保存到外部的/var/lib/systemd/coredump/ 目录中。

进程在接收到信号后的行为取决于某些特定的因素(详见core(5) 手册),特别需要注意的是,仅在相关系统资源充足且未超出资源限制的前提下,才会进行内存转储操作。

如果在调用 systemd-coredump 时使用了--backtrace 选项,那么在 systemd-coredump的标准输入(STDIN)上必须存在一条符合Journal Export Format格式的日志,这条日志必须包含一个 MESSAGE= 字段,并且任何其他元数据字段在调用者看来都必须是合情合理的。 systemd-coredump将会按照它自己从内核中接收内存转储的方式,在这条日志中添加额外的元数据字段。注意,在这种模式下,内存转储将不会保存在日志中。

配置

对于被 systemd 进程启动的程序来说,可以通过LimitCore= 指令来设置资源限制,详见systemd.exec(5) 手册。

为了被操作系统内核用作内存转储处理器,systemd-coredump 必须被配置到sysctl(8)kernel.core_pattern 变量中。此变量的语法详见core(5) 手册。systemd 安装的 /usr/lib/sysctl.d/50-coredump.conf 文件就依据该语法配置了kernel.core_pattern 变量的默认值。如果想要使用不同的配置,那么可以根据sysctl.d(5)规则来屏蔽或覆盖此文件。修改 sysctl 配置之后,必须要刷新内核参数才能真正生效,详见sysctl(8)systemd-sysctl.service(8) 手册。

如果想要以 --backtrace 模式运行,那么必须在发送端安装一个适当的回溯处理程序(backtracehandler)。例如,对于python(1) 来说,这就意味着必须安装一个 sys.excepthook 钩子,详见systemd-coredump-python 手册。

systemd-coredump 自身的行为由/etc/systemd/coredump.conf 配置文件与对应的/etc/systemd/coredump.conf.d/*.conf 配置片段共同决定,详见coredump.conf(5) 手册。因为每发生一次内核转储都会调用一个 systemd-coredump 新实例,所以,这些配置文件的变化将会立即体现在下一次内核转储调用调用的新实例上。

内核转储文件所占用的磁盘资源受两种不同方式的约束:(1)占用磁盘空间的大小受 /etc/systemd/coredump.conf 配置文件以及对应的配置片段的约束;(2)占用磁盘时间的长短受 systemd-tmpfiles 配置的约束(对应的配置文件默认位于 /usr/lib/tmpfiles.d/systemd.conf)。

禁止处理内核转储

如果想要避免 systemd-coredump 在处理内核转储时对系统资源的大量占用,那么可以将

Storage=none
ProcessSizeMax=0

写入coredump.conf(5) 中。

用法

存储在日志中的数据,可以按照常规使用journalctl(1)进行查看。coredumpctl(1)可以用于提取已保存的内存转储,而不必关心实际的保存方式与位置。如果想要显示相关信息或做进一步处理,可以将输出内容管道传递给例如 gdb 这样的工具。

参见

coredump.conf(5),coredumpctl(1),systemd-journald.service(8),systemd-tmpfiles(8),core(5),sysctl.d(5),systemd-sysctl.service(8).

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文