CentOS开启coredump转储并生成core文件的配置

本文介绍如何在CentOS系统中开启core dump功能,并详细配置core文件的生成路径、名称格式,确保C/C++程序崩溃时能生成详细的core文件,便于后续gdb调试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在CentOS或者suse等Linux系统中默认是关闭coredump核心转储的,也就不会产生core文件。由于在C/C++开发中会用到gdb调试,所以需要开启coredump功能。下面是具体的配置命令,可以保存为一个简单的shell脚本执行。

#!/bin/bash

### Filename: coredumpshell.sh
### Description: enable coredump and format the name of core file on centos system

# enable coredump whith unlimited file-size for all users
echo -e "\n# enable coredump whith unlimited file-size for all users\n* soft core unlimited" >> /etc/security/limits.conf

# set the path of core file with permission 777 
cd /mydata && mkdir corefile && chmod 777 corefile

# format the name of core file.   
# %% – 符号%
# %p – 进程号
# %u – 进程用户id
# %g – 进程用户组id
# %s – 生成core文件时收到的信号
# %t – 生成core文件的时间戳(seconds since 0:00h, 1 Jan 1970)
# %h – 主机名
# %e – 程序文件名
echo -e "/mydata/corefile/core-%e-%s-%u-%g-%p-%t" > /proc/sys/kernel/core_pattern

# for centos7 system(update 2017.2.3 21:44)
echo -e "/mydata/corefile/core-%e-%s-%u-%g-%p-%t" > /etc/sysctl.conf

# suffix of the core file name
echo -e "1" > /proc/sys/kernel/core_uses_pid

其中的mydata目录改成自己程序的目录就行了
Linux终端上执行完上面的脚本后,退出并重新登录即可生效。可以通过ulimit -a命令查看效果,如下图所示:
在这里插入图片描述
最后,写了一个简单C++程序测试CentOS是否生成了相应的core文件。

#include <stdio.h>

#include <iostream>
using namespace std;

int main()
{
	std::cout << "Hello World" << std::endl;
    char* p = NULL;
    *p = 0;
    return 0;
}

程序的路径是在

/root/gdb_test

先运行一下

echo "/root/gdb_test/core-%e-%p-%t" > /proc/sys/kernel/core_pattern

使用命令g++ test.cpp -o test编译后执行,让进程报错,这时在/root/gdb_test/目录就生成了相应的core文件core-test-4832-1588588728

[root@centos-linux gdb_test]# ./test
Hello World
段错误(吐核)
-rw-------. 1 root root 413696 54 18:38 core-test-4832-1588588728

每次重启CentOS7后,由于proc目录是动态更新的,所以系统会初始化core_pattern的值。如果想永久设置coredump文件为上面的格式,那么需要使用编辑文件 /etc/sysctl.conf ,加入kernel.core_pattern=/mydata/corefile/core-%e-%s-%u-%g-%p-%t,然后使用命令sysctl -p /etc/sysctl.conf重新加载。

#!/bin/bash

### Filename: coredumpshell.sh
### Description: enable coredump and format the name of core file on centos system

# enable coredump whith unlimited file-size for all users
echo -e "\n# enable coredump whith unlimited file-size for all users\n* soft core unlimited" >> /etc/security/limits.conf

# format the name of core file.   
# %% – 符号%
# %p – 进程号
# %u – 进程用户id
# %g – 进程用户组id
# %s – 生成core文件时收到的信号
# %t – 生成core文件的时间戳(seconds since 0:00h, 1 Jan 1970)
# %h – 主机名
# %e – 程序文件名    
# for centos7 system(update 2017.4.2 21:44)
echo -e "\nkernel.core_pattern=/mydata/corefile/core-%e-%s-%u-%g-%p-%t" >> /etc/sysctl.conf

# suffix of the core file name
echo -e "1" > /proc/sys/kernel/core_uses_pid

sysctl -p /etc/sysctl.conf
<think>嗯,用户问的是如何在BCLinux系统上开启systemd-coredump服务。首先,我需要确认BCLinux是基于哪个发行版的。通常来说,BCLinux可能是基于RHEL或者CentOS的,所以应该使用systemd作为初始化系统。 接下来,systemd-coredump服务的作用是处理核心转储文件,当程序崩溃时自动记录信息。用户可能遇到了需要调试程序崩溃的情况,或者想配置系统以生成核心转储文件。需要先检查当前系统是否已经启用了这个服务。可能需要运行systemctl status systemd-coredump.service来查看状态。 如果服务没有运行,可能需要安装相关的软件包。在基于RHEL的系统里,可能包名是systemd-coredump,但需要确认是否存在。使用yum或dnf来安装,比如sudo dnf install systemd-coredump。 安装完成后,启用启动服务,使用systemctl enable --now命令。然后需要检查配置文件,通常是/etc/systemd/coredump.conf,可能需要调整存储位置、压缩选项等参数。修改后重新加载systemd配置。 另外,还要考虑系统的ulimit设置,确保核心转储文件的大小不受限制,可以通过ulimit -c unlimited设置。但用户可能需要永久生效,所以需要在/etc/security/limits.conf或者使用sysctl的kernel.core_pattern。 测试的时候,可以写个测试程序故意崩溃,比如用C语言写一个段错误的程序,然后运行看看是否生成核心转储。检查/var/lib/systemd/coredump目录是否有文件生成。 可能用户遇到的问题包括服务未安装、配置错误、权限问题或者存储路径不存在。需要提醒用户检查这些方面,确保有足够的磁盘空间。 总结步骤的话,应该分点说明:安装服务、启用服务、配置参数、设置ulimit、测试验证。最后给出注意事项,比如路径权限、磁盘空间和安全性考虑。这样用户能一步步跟着操作,确保服务正常开启。</think>在BCLinux系统中开启`systemd-coredump`服务的步骤如下: --- ### 一、什么是systemd-coredump? 这是systemd自带的核心转储(core dump)管理服务,当程序崩溃时: 1. 自动捕获崩溃时的内存状态 2. 生成压缩的core dump文件 3. 记录崩溃日志到journald --- ### 二、启用步骤 #### 1. 检查服务状态 ```bash systemctl status systemd-coredump.service ``` - 如果显示`inactive (dead)`则需要启用 #### 2. 安装服务(如未安装) ```bash sudo yum install systemd-coredump # 适用于yum系 # 或 sudo dnf install systemd-coredump # 适用于dnf系 ``` #### 3. 启用启动服务 ```bash sudo systemctl enable --now systemd-coredump.service ``` #### 4. 配置核心转储(可选) 编辑配置文件: ```bash sudo vim /etc/systemd/coredump.conf ``` 关键参数: ```ini [Coredump] #Storage=external # 默认存储到journald #Compress=yes # 启用压缩 #MaxBytes=1G # 最大单个文件大小 ``` #### 5. 重新加载配置 ```bash sudo systemctl daemon-reload ``` --- ### 三、验证配置 #### 1. 触发测试崩溃 ```bash kill -s SIGSEGV $$ # 故意制造段错误 ``` #### 2. 检查转储文件 ```bash coredumpctl list ``` 默认存储路径: ``` /var/lib/systemd/coredump/ ``` --- ### 四、重要补充配置 #### 1. 设置核心转储大小限制 ```bash # 临时生效 ulimit -c unlimited # 永久生效(添加至/etc/security/limits.conf) * soft core unlimited ``` #### 2. 设置核心转储路径模式 ```bash echo "kernel.core_pattern=|/usr/lib/systemd/systemd-coredump %P %u %g %s %t %c %h" | sudo tee /etc/sysctl.d/50-coredump.conf sudo sysctl -p /etc/sysctl.d/50-coredump.conf ``` --- ### 五、常见问题排查 1. **无转储文件生成**: - 检查`/var/lib/systemd/coredump`目录权限 - 确认磁盘空间充足 - 检查`ulimit -c`设置 2. **查看具体转储信息**: ```bash coredumpctl info [PID/NAME] ``` 3. **禁用服务**: ```bash sudo systemctl mask systemd-coredump.service ``` --- ### 六、注意事项 1. 核心转储可能包含敏感信息 2. 生产环境建议限制存储空间 3. 调试完成后建议恢复默认安全设置 按照以上步骤操作后,系统即可自动捕获管理核心转储文件。建议根据实际需求调整存储策略和保留策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值