0

0

linux怎么查看开机日志_linux检查启动故障【步骤】

冰火之心

冰火之心

发布时间:2026-03-14 02:43:33

|

782人浏览过

|

来源于php中文网

原创

journalctl -b 是查本次启动完整日志的首选命令,它结构化、时间准、来源清;dmesg 专用于内核早期硬件/驱动问题;/var/log/ 下文本日志仅作交叉验证。

linux怎么查看开机日志_linux检查启动故障【步骤】

直接看本次启动的完整日志用 journalctl -b

绝大多数现代 Linux(Ubuntu 22.04+、CentOS 7+、Debian 11+)都用 systemd,journalctl -b 就是查“这次开机从内核加载到桌面/服务就绪”的全部记录,不混入其他运行时日志。它比翻文件靠谱得多——因为 journal 是结构化存储,时间戳准、来源清、服务归属明确。

  • journalctl -b 默认按时间正序输出,最新条目在最后;加 --no-pager 可避免卡在 less 里
  • 想快速扫错误?用 journalctl -b -p err ——只显示 err 及更严重级别(crit/alert/emerg),跳过大量 info 级干扰
  • 别用 journalctl | grep failed:journalctl 自带过滤,管道进 grep 会丢失优先级、服务名等元数据,且可能截断长行
  • 如果系统刚崩了进不去图形界面,SSH 也连不上,先别急着重装——只要还能进单用户模式或 recovery shell,journalctl -b 通常仍可用(journald 默认内存缓存,但若启用了持久化,日志已落盘到 /var/log/journal/

硬件/驱动问题优先查 dmesg,不是 journalctl

dmesg 输出的是内核环形缓冲区原始内容,从 GRUB 把控制权交给 kernel 的第一行开始,包括 CPU 检测、内存映射、PCIe 设备枚举、驱动 probe 成败——这些信息 journalctl -b 会收录,但会被格式化、截断,甚至因 journald 启动晚而漏掉 early boot 阶段。

  • dmesg -l err,warndmesg | grep -i "error" 更可靠:前者按内核定义的 log level 过滤,后者可能匹配到正常字符串(比如某模块名含 “error”)
  • dmesg -T 加人类可读时间戳,但注意:该时间基于系统当前时钟,若 RTC 不准或 NTP 没同步,早期日志时间可能偏移;诊断冷启动失败时,优先用默认无 -T 的输出
  • 如果 dmesg 输出为空或极短,说明内核可能根本没跑起来(如 initramfs 解包失败、根文件系统找不到),这时要回头查 GRUB 参数或 initrd 内容,而不是继续翻日志
  • dmesg 缓冲区大小有限(通常 64K~1M),老消息会被覆盖;若需长期保留,得靠 systemd-journald 持久化或手动执行 dmesg > /tmp/dmesg.boot 抓快照

/var/log/boot.log/var/log/messages 只作辅助验证

这些文本日志是传统 SysVinit 遗留机制,现在多数发行版已不主动写入它们——除非你手动启用了 rsyslog 转发或禁用了 journald。它们的价值在于交叉验证:比如 journalctl -b 显示某服务启动超时,而 /var/log/messages 里同一时间点有 “SELinux denied” 记录,那问题大概率不在服务本身。

阿里云AI平台
阿里云AI平台

阿里云AI平台

下载
  • /var/log/boot.log 在 CentOS/RHEL 系统中可能有内容,但在 Ubuntu/Debian 上常为空或仅含 minimal 初始化信息;别把它当主依据
  • /var/log/messages(RHEL 系)或 /var/log/syslog(Debian 系)是 syslog 守护进程汇总的日志,但 systemd 下很多消息根本不会走这路,尤其 early boot 阶段
  • tail -n 50 /var/log/messages 快速瞄一眼没问题,但若发现关键报错不在里面,别怀疑自己漏看了——很可能它压根就没被 syslog 接收
  • 如果 journalctldmesg 都没线索,再检查 /var/log/journal/ 目录是否存在、是否可读;若为空,确认 Storage=persistent 是否在 /etc/systemd/journald.conf 中启用

查历史启动(比如上一次成功/失败)必须用 -b -1,不能靠文件修改时间

系统重启后,/var/log/ 下的文本日志文件不会自动按启动会话切分,而 journal 会为每次 boot 分配唯一 ID。所以想对比“这次崩了 vs 上次好好的”,journalctl -b -1 是唯一可靠方式。

  • journalctl -b -1 查上一次;journalctl -b -2 查上上次……最多支持到 -b -10 左右,具体取决于 SystemMaxUse 配置
  • 别用 ls -lt /var/log/messages 文件时间戳来判断“上次启动”——日志轮转(logrotate)会改时间,且多会话下文件内容是混在一起的
  • 如果 journalctl -b -1 报错 “No such boot ID”,说明该次启动日志未持久化保存,要么 journald 没配置持久化,要么那次启动时磁盘已满或 journal 目录权限异常
  • 需要导出某次启动日志做离线分析?用 journalctl -b -1 --all --no-pager > boot-previous.log--all 确保不丢二进制字段(如堆栈),--no-pager 避免分页器污染输出

真正卡住的时候,90% 的人会反复刷 journalctl -b 却忽略 dmesg -l err,warn 里的硬件报错,或者把空的 /var/log/boot.log 当成证据。启动日志不是“看全了就行”,而是要分层:内核层(dmesg)、初始化层(journalctl -b)、服务层(journalctl -u xxx),每层失效点不同,工具也不同。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.10.12

scripterror怎么解决
scripterror怎么解决

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

492

2023.10.18

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

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

382

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1568

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

651

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

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