linux 环境收集core文件步骤

Linux环境下进程发生异常而挂掉,通常很难查找原因,但是一般Linux内核给我们提供的核心文件,记录了进程在崩溃时候的信息,在C语言类的大型项目中,有助于深入定位。其配置流程如下:

1 查看生成core文件开关是否开启 ulimit -a

c 复制代码
core file size          (blocks, -c) 0   		// 表明未开启
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 2061196
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1048576
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 1048576
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

2 ulimit -c [kbytes]可以设置系统允许生成的core文件大小;

c 复制代码
ulimit -c unlimited     // 不限制core文件的大小

core file size          (blocks, -c) unlimited
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 2061406
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 524288
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 131072
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

上述方式不是永久生效的,要使其永久生效,可以进行如下设置

1 vi /etc/security/limits.d/20-nproc.conf

c 复制代码
*          soft    nproc     unlimited
root       soft    nproc     unlimited
postgres   soft    core      unlimited
postgres   hard    core      unlimited 

2 指定core文件的名字与生成路径

执行# vim /etc/sysctl.conf,进入编辑模式,加入下面两行

c 复制代码
kernel.core_pattern=/var/core/core_%e_%p
kernel.core_uses_pid=0

注释: %e dump文件名      %p 进程号

3 执行sysctl -p /etc/sysctl.conf,使其修生效。

参考:https://blog.csdn.net/luronggui/article/details/128728235

相关推荐
oradh20 分钟前
Oracle数据库中的Java概述
java·数据库·oracle·sql基础·oracle数据库java概述
2301_7950997440 分钟前
如何优化SQL中大批量数据的物理删除_分批次与间隔控制
jvm·数据库·python
2301_812539671 小时前
CSS如何引入CSS形状生成器_通过自定义属性实现图形化样式
jvm·数据库·python
maxmaxma1 小时前
Claude Code集成DeepSeek-V4-pro全栈开发 - MCP 连接数据库
数据库·ai
lb29171 小时前
navicat连接Oracle报错了:“身份证明检索失败”
数据库·oracle·连接oracle数据库报错
xfhuangfu1 小时前
Oracle 12.2 ORA-600 数据库发生重启案例
数据库·oracle
m0_609160491 小时前
Golang怎么实现数据库连接重试_Golang如何在启动时重试连接直到数据库就绪【技巧】
jvm·数据库·python
罗超驿1 小时前
8.数据库约束学习笔记:从非空、默认、唯一与主键约束到主键自增
数据库·mysql
谁似人间西林客2 小时前
工厂大脑如何让汽车制造告别“救火式”运维?
运维·汽车·制造
zxrhhm2 小时前
PostgreSQL 大规模随机数据生成完整指南
大数据·数据库·postgresql