0

0

Linux 内核日志分析与排错技巧

冷炫風刃

冷炫風刃

发布时间:2026-02-24 14:53:11

|

192人浏览过

|

来源于php中文网

原创

dmesg 日志需聚焦设备初始化失败、内存异常、驱动报错三类信号,用 -t 加时间戳、-l err,warn 限级别、--since 限时间、按子系统(ata/nvme/usb等)过滤,并区分 dmesg 与 journalctl -k 的数据源差异。

linux 内核日志分析与排错技巧

怎么看 dmesg 输出里真正有用的那几行

内核日志动辄几千行,dmesg 默认输出全是噪音。关键不是“全看”,而是过滤出设备初始化失败、内存分配异常、驱动报错这几类信号。用 dmesg -T 加时间戳能快速定位问题发生时段;配合 dmesg | grep -i "error\|fail\|warn" 是基础操作,但要注意:很多真实错误不带 error 字样,比如 nvme 0000:01:00.0: PCIe Bus Error 这种就只写 “Bus Error”。

更可靠的做法是按子系统过滤:dmesg | grep -E "(ata|nvme|usb|pci|iommu)",再结合 dmesg -l err,warn 只看错误和警告级别。别忘了加 --since "2024-05-20 14:30:00"(需 systemd)限定时间范围——重启后日志会被清空,但 dmesg 缓存里只保留最近一次启动的内容。

journalctl -kdmesg 输出为啥不一样

因为 journalctl -k 读的是 journald 持久化后的内核日志,而 dmesg 直接读内核环形缓冲区(/dev/kmsg)。两者内容可能差几百行:journald 默认只保存部分日志,且受 Storage=volatile 或磁盘空间限制影响;dmesg 则只保留内核缓冲区当前容量(通常 64KB 左右),旧日志会被覆盖。

  • 要查历史重启前的日志,必须用 journalctl -k --all --no-pager,并确认 /var/log/journal/ 存在且未被 systemd-journald 清理
  • 如果 journalctl -k 空但 dmesg 有内容,说明 journald 没启用持久存储,改 /etc/systemd/journald.conf 中的 Storage=persistent 并重启 systemd-journald
  • dmesg -C 会清空缓冲区——别在排查中误用,它不会影响 journal 日志

遇到 Kernel panic - not syncing: VFS: Unable to mount root fs 怎么快速定位

这错误意味着内核找不到或无法挂载根文件系统,不是驱动没加载就是 initramfs 里缺模块。先别急着重启,用 dmesg | tail -n 50 看 panic 前最后几十行,重点找三类线索:

Play.ht
Play.ht

根据文本生成多种逼真的语音

下载

  • 是否有 dracutinitrd 相关报错,比如 modprobe: FATAL: Module xxx not found in directory /lib/modules/...
  • 是否识别到了正确磁盘:搜 sd[a-z]nvm[ae],确认 scsi/nvme 驱动已加载,且设备路径(如 /dev/nvme0n1p2)和 root= 内核参数一致
  • 是否提示 Failed to find suitable root device —— 很可能是 initramfs 没包含 lvm2mdraid 工具,得重做 initramfs(dracut -fupdate-initramfs -u

为什么 printk 日志级别调高了还是看不到驱动输出

内核日志有两级控制:一是 printk 的调用级别(KERN_ERR, KERN_INFO 等),二是当前控制台日志级别(/proc/sys/kernel/printk 第一个数字)。即使驱动用了 pr_info(),如果控制台级别设为 4(即只显示 KERN_ERR 及以上),那 info 就不会输出到终端或 dmesg 缓冲区。

  • 临时提高:运行 sudo dmesg -n 8(8 = 最高,显示所有)
  • 永久生效需改 /etc/sysctl.confkernel.printk = 8 4 1 7,然后 sysctl -p
  • 注意:某些驱动(如 vfio-pci)默认关闭详细日志,需加内核参数 vfio-pci.enable_sriov=1 vfio-pci.disable_idle_d3=1 或通过 debugfs 控制
  • 别依赖 printk 查高频事件——它本身有锁开销,大量调用会拖慢系统甚至掩盖真问题

内核日志不是文本搜索游戏,关键是把设备链路(PCIe → 总线驱动 → 设备驱动 → 文件系统)和日志级别、存储路径、时间窗口这四者对齐。漏掉任意一环,看到的都可能是断章取义的“证据”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

391

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

348

2023.10.25

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

71

2025.10.23

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1541

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

715

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

792

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

584

2023.07.06

苹果官网入口与在线访问指南_中国站点快速直达与iPhone查看方法
苹果官网入口与在线访问指南_中国站点快速直达与iPhone查看方法

本专题汇总苹果官网最新可用入口及中国站点访问方式,涵盖官网直达链接、iPhone官方页面查看方法与常见访问说明,帮助用户快速进入苹果官方网站,便捷了解产品信息与官方服务。

7

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.6万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号