首先安装必选包:

apt-get -y install aptitude kdump-tools crash kexec-tools makedumpfile linux-image-`uname -r`-dbg

aptitude full-upgrade # 避免运行的内核版本与调试的版本不一致导致无法调试

Kdump配置文件 /etc/default/kdump-tools 关键部分

USE_KDUMP=1

KDUMP_SYSCTL="kernel.panic_on_oops=1"

KDUMP_KERNEL=/boot/vmlinuz-3.16.0-4-amd64

KDUMP_INITRD=/boot/initrd.img-3.16.0-4-amd64

KDUMP_COREDIR="/data/crash"

KDUMP_FAIL_CMD="reboot -f"

DEBUG_KERNEL=/usr/lib/debug/vmlinux-3.16.0-4-amd64

MAKEDUMP_ARGS="-c -d 31"

KDUMP_CMDLINE="crashkernel=512M"

crashkernel大小配比,正常情况崩溃后1分钟左右会自动重启、配置不正确会导致重启卡住黑屏不动。

内存大小crashkernel=

0 - 12G128M

13 - 48G256M

49 - 128G512M

129 - 256G1G *(896M, 768M o或 512M)

Grub配置文件/etc/default/grub关键部分

GRUB_CMDLINE_LINUX_DEFAULT="nmi_watchdog=1 crashkernel=512M"

Sysctl配置文件/etc/sysctl.conf关键部分

kernel.sysrq = 1

kernel.watchdog = 1

kernel.nmi_watchdog = 1

kernel.panic_on_oops = 1

kernel.softlockup_panic = 1

kernel.watchdog_thresh = 10

重启让配置生效

update-grub

reboot -f

kdump-config load

kdump-config show

校验

# cat /proc/cmdline

BOOT_IMAGE=/boot/vmlinuz-3.16.0-4-amd64 root=UUID=a58ab901-00aa-4f8b-b3eb-d352fc72233 ro net.ifnames=0 thash_entries=1048576 rhash_entries=1048576 biosdevname=0 nohz=off enforcing=0 ipv6.disable_ipv6=1 nmi_watchdog=1 selinux=0 transparent_hugepage=never cgroup_enable=memory swapaccount=1 vga=771 crashkernel=512M

# kdump-config test

USE_KDUMP: 1

KDUMP_SYSCTL: kernel.panic_on_oops=1

KDUMP_COREDIR: /data/crash

crashkernel addr: 0x2e000000

kdump kernel addr:

kdump kernel:

/boot/vmlinuz-3.16.0-4-amd64

kdump initrd:

/boot/initrd.img-3.16.0-4-amd64

debug kernel:

/usr/lib/debug/vmlinux-3.16.0-4-amd64

kexec command to be used:

/sbin/kexec -p --command-line="BOOT_IMAGE=/boot/vmlinuz-3.16.0-4-amd64 root=UUID=a58ab901-00aa-4f8b-b3eb-d352fc7f6acb ro net.ifnames=0 thash_entries=1048576 rhash_entries=1048576 biosdevname=0 nohz=off enforcing=0 ipv6.disable_ipv6=1 nmi_watchdog=1 selinux=0 transparent_hugepage=never cgroup_enable=memory swapaccount=1 vga=771 irqpoll maxcpus=1 nousb systemd.unit=kdump-tools.service crashkernel=512M" --initrd=/boot/initrd.img-3.16.0-4-amd64 /boot/vmlinuz-3.16.0-4-amd64

测试

echo c > /proc/sysrq-trigger

分析

crash /data/crash/201609010252/dump.201609012233 /usr/lib/debug/lib/modules/3.16.0-4-amd64/vmlinux

开始欢快的调试之旅

常用错误 :

WARNING: kernel version inconsistency between vmlinux and dumpfile # 版本不一致,full-upgrade 一下。

崩溃后系统不重启。 # 请检查 sysctl 、 crashkernel 及 nmi_watchdog 的设定!

linux内核崩溃无日志,教你如何捕捉内核崩溃信息相关推荐

  1. android崩溃无日志,Android 收集Crash日志----UncaughtExceptionHandler

    Android应用不可避免地会发生crash,也称之为崩溃,无论你的程序写得多么完美,总是无法完全避免crash的发生,可能是由于Android系统底层的bug,也可能是由于不充分的机型适配或者是糟糕 ...

  2. linux下root无权限问题,解决Ubuntu中sudoers崩溃而无root权限的问题

    1.重新启动Ubuntu系统,启动的时候按住Esc键,可以看到引导选项: 2.可以看到引导选项列表中,有一项的末尾括号里是这样的(recovery mode),也就是恢复模式,选择这项,回车继续: 3 ...

  3. 新手用计算机崩溃了,计算机崩溃,详细教您如果计算机频繁崩溃怎么办

    计算机已经使用了很长时间,并且用户经常会遇到崩溃. 对于经常使用的计算机来说,这相对容易解决,但是对于一些新手来说却很难解决,因此我感到非常担忧,如何解决这些问题?下面,我将向您介绍如何解决计算机频繁 ...

  4. 蓝鸽服务器崩溃怎样从装系统,系统崩溃,小编教你怎么解决系统崩溃的问题

    小伙伴们最近都好像在为一个电脑问题而困扰呢,让小编来猜猜是什么问题呢.是不是关于系统崩溃的问题呢?哈哈,我猜对了吧~既然猜对了,那接下来就应该跟你们分享一下解决系统崩溃的问题. 我们在使用电脑的时候, ...

  5. linux kernel内核、驱动日志调试方法(一)

    本文是对网络资料进行总结归纳,抄录其他博客资料,如有侵权,请告知,进行删除 一:通过打印调试printk printk是打印内核消息的函数,printk通过附加不同日志级别(loglevel)或者说消 ...

  6. SQL SERVER 2008 2012 数据库损坏 或者 附加数据库 无日志文件出错

    最近不知道什么原因,我本人的数据在删除日志文件后,在此附加时一直提示数据库无日志文件,数据库损坏等错误信息而导致无法附加数据库,查阅资料后,经过多番测试终于成功将数据库附加上去了.在此做个总结. 1. ...

  7. linux内核驱动ldd3_手把手教Linux驱动7内核互斥锁

    互斥体概述 信号量是在并行处理环境中对多个处理器访问某个公共资源进行保护的机制,mutex用于互斥操作.信号量的count初始化为1,down()/up()也可以实现类似mutex的作用. mutex ...

  8. log4j2 在开发环境(win)和测试环境(win)下均可以输出日志,但在生产环境(linux)无日志输出

    一.问题说明:在开发环境和测试环境下均可以输出日志,但在生产环境无日志输出. 二.发现问题:          1,系统不同:         开发环境和测试环境(windows)         生 ...

  9. linux系统中的日志管理

    Linux系统中的日志管理 1 实验环境 2 journald日志服务 2.1 journalctl命令的用法 2.2 用journald服务永久存放日志 3 rsyslog日志服务 3.1 自定义日 ...

最新文章

  1. 你确定你理解内存分配吗?
  2. 跑赢A股95%的公司,半年大涨115%!明年的海尔智家更令人期待!
  3. vue axios 跨域_SpringBoot+Vue从零开始搭建系统(三)前后端整合二
  4. MFC添加自定义消息
  5. python inspect模块解析
  6. 9. JEB 1.5插件编写一
  7. (转)MongoDB入门分享-笔记整理精选
  8. sever client
  9. 2021-08-19 定制错误页面,共用页面设置
  10. 页面回发(PostBack)后,滚动条位置保持不变
  11. EasyClick易点云测 EC超级拓展插件laoleng.js
  12. node打印彩色文字
  13. pdf怎么合并在一起?
  14. python中的坐标轴的画法
  15. C语言输入一串数字字符串,C语言——输入一个字符串,将连续数字字符转换为数字(示例代码)...
  16. CWRU数据集-美国西储大学轴承数据
  17. LeetCode数据结构基础---2021/8/18
  18. 史上最简单笔记本选购攻略(给对笔记本配置完全不懂的小白,建议收藏)
  19. ETHEOS开发资源及工具集合(完整汇总版)
  20. 数字孪生服务提供模式及典型案例

热门文章

  1. Mysql高级调优篇——前言简介
  2. celery的初次使用
  3. linux系统版本间的区别是什么?内核又是什么
  4. ACMNO.46 A+B问题 问题描述 输入A、B,输出A+B。(别被数值范围所局限)
  5. OpenCV中导向滤波介绍与应用
  6. 如何在超大分辨率的图片中检测目标?
  7. 没有顶会的CV/NLP方向的博士生毕业出路在哪里?
  8. 实用技能 | OpenCV算法程序导出 DLL与调用演示
  9. 【从零学习OpenCV 4】了解OpenCV的模块架构
  10. redis3.2集群搭建