在Linux操作系统中如何查看系统全部重启的详细历史记录?

在Linux系统管理中,掌握系统重启记录的查看方法至关重要,无论是排查故障、分析系统稳定性,还是审计系统操作,都需要准确获取重启时间、原因及相关日志信息,Linux系统通过多种机制记录重启事件,本文将详细介绍不同场景下查看重启记录的实用方法,涵盖命令工具、日志文件及过滤技巧,帮助用户根据需求选择合适方案。

linux 如何查看重启记录

使用last命令查看重启记录

last是Linux系统中查看用户登录、系统关机及重启历史记录的常用命令,其数据来源为/var/log/wtmp文件(二进制格式,记录登录、关机、重启等事件),默认执行last会显示所有历史记录,包括用户登录、系统关机和重启事件,其中重启记录的用户名通常显示为reboot,终端显示为system boot

常用参数及示例

  • 查看所有重启记录last reboot,输出包含重启时间、终端位置、持续时间等信息。
    reboot   system boot  5.15.0-88-generic Tue Oct 10 14:30 still running  
    reboot   system boot  5.15.0-88-generic Mon Oct 9 09:15 - 14:29 (1+05:14)  

    第一列reboot表示事件类型,第二列system boot表示启动方式,第三列内核版本,第四列重启时间,第五列持续时间(still running表示系统仍在运行)。

  • 限制显示行数last reboot -n 5仅显示最近5次重启记录。
  • 指定日志文件:若/var/log/wtmp路径异常,可通过-f参数指定,如last reboot -f /var/log/wtmp.1(查看轮转后的日志文件)。

注意事项

/var/log/wtmp文件会随系统运行持续增长,管理员可通过logrotate工具配置轮转策略(如每周轮转、保留4周),避免占用过多磁盘空间,若文件损坏或缺失,last命令将无法读取重启记录。

分析/var/log/wtmp/var/log/btmp文件

/var/log/wtmp是记录重启、登录、关机的核心文件,而/var/log/btmp记录失败登录事件(与重启无关),虽然wtmp为二进制文件无法直接查看,但可通过strings命令提取文本信息:

strings /var/log/wtmp | grep reboot

输出结果可能包含重启时间戳和终端信息,但格式不如last命令直观,可通过ls -l /var/log/wtmp查看文件修改时间,若修改时间早于系统实际重启时间,可能暗示日志文件异常或被篡改。

linux 如何查看重启记录

使用journalctl查看systemd系统的重启日志

对于采用systemd初始化系统的Linux发行版(如Ubuntu 16.04+、CentOS 7+),journalctl是查看系统日志的核心工具,重启记录会被结构化存储在systemd日志中。

常用命令及场景

  • 查看重启服务日志journalctl -u systemd-reboot.service,显示systemd重启服务的详细日志,包含启动时间、依赖服务状态及错误信息。
  • 查看本次启动以来的日志journalctl -b,结合-p err可筛选本次启动中的错误日志(如导致重启的内核panic或服务崩溃):
    journalctl -b -p err | grep -i reboot
  • 查看内核消息journalctl -k,显示内核环缓冲区中的消息,重启时的硬件初始化、驱动加载信息(如[ 0.123456] Linux version 5.15.0-88-generic)会在此记录。
  • 按时间范围过滤journalctl --since "2023-10-01 00:00:00" --until "2023-10-31 23:59:59" -u systemd-reboot,查看指定月份的重启日志。

优势

journalctl支持日志持久化(存储在/var/log/journal/)、优先级过滤(如-p emerg-p debug)、字段匹配(如_SYSTEMD_UNIT=systemd-reboot.service),适合深入分析重启原因。

通过uptimedmesg辅助判断

  • uptime命令:显示系统当前运行时间、登录用户数等信息,其up字段可辅助判断是否发生重启,若系统显示up 2 min,且管理员未手动重启,则可能发生了意外重启,但该命令无法直接显示重启时间,仅能作为初步判断工具。
  • dmesg命令:查看内核环缓冲区消息,重启时的内核启动参数、硬件检测错误(如[ 1.567890] ACPI: [Firmware Bug])会被记录,通过dmesg -T可添加时间戳,便于定位重启时间点:
    dmesg -T | grep "Linux version"

    输出类似[Tue Oct 10 14:30:15 2023] Linux version 5.15.0-88-generic (buildd@lcy01-amd64-013)的信息,可确定最近一次启动的内核版本和时间。

检查syslogrsyslog日志

对于使用syslog或rsyslog的旧版系统(如CentOS 6及更早版本),重启记录可能保存在/var/log/syslog/var/log/messages中,通过grep搜索关键词可提取相关信息:

grep -i "reboot|systemd.*reboot" /var/log/syslog

或搜索内核重启消息:

linux 如何查看重启记录

grep "Kernel is restarting" /var/log/messages

此类日志通常包含系统服务的启动停止状态,但需注意日志可能因轮转而分散在多个文件中(如/var/log/syslog.1/var/log/syslog.2.gz)。

不同方法对比总结

为方便选择,以下表格总结各方法的适用场景及特点:

方法名称 适用场景 命令示例 说明 优点 缺点
last 快速查看重启时间列表 last reboot -n 5 重启时间、终端、持续时间 简单直观,无需额外工具 无法查看重启原因,依赖wtmp文件
journalctl systemd系统,分析重启原因 journalctl -u systemd-reboot -b 结构化日志,含时间、服务、错误 日志详细,支持多维度过滤 仅适用于systemd系统
dmesg 查看内核启动信息 dmesg -T | grep reboot 内核消息,时间戳 可定位硬件/驱动问题 需手动筛选信息
uptime 快速判断是否重启 uptime 系统运行时间 极简,快速判断 无法显示具体时间
grep syslog syslog系统,旧版Linux grep reboot /var/log/syslog 服务/内核日志 兼容旧系统 日志分散,需手动搜索

相关问答FAQs

问题1:为什么执行last reboot看不到重启记录?
解答:可能原因包括:

  1. /var/log/wtmp文件不存在或损坏:可通过ls -l /var/log/wtmp检查,若不存在需手动创建(touch /var/log/wtmp)并设置权限(chmod 664 /var/log/wtmp);
  2. 系统从未重启过(新安装的系统);
  3. 日志轮转导致旧记录被清理:检查/var/log/wtmp.*备份文件(如last reboot -f /var/log/wtmp.1);
  4. 使用了非标准日志路径:若/var/log/wtmp被移动到其他位置,需通过-f参数指定正确路径。

问题2:如何查看特定时间段内的重启记录?
解答:不同方法支持不同的时间过滤方式:

  1. last reboot:结合grepawk处理时间,例如last reboot | grep "Oct 15" | head -5查看10月15日的重启记录;
  2. journalctl:使用--since--until参数(支持ISO 8601格式),如journalctl -u systemd-reboot --since "2023-10-01 00:00:00" --until "2023-10-31 23:59:59"
  3. dmesg:通过-T显示时间戳后用grep过滤,如dmesg -T | grep "2023-10-15" | grep reboot
  4. grep syslog:用grep结合日期,如grep "Oct 15" /var/log/syslog | grep reboot,注意时间格式需与日志中的格式一致(如last支持英文月份缩写,journalctl支持YYYY-MM-DD HH:MM:SS)。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/22280.html

(0)
酷番叔酷番叔
上一篇 6小时前
下一篇 5小时前

相关推荐

  • linux中如何安装flash

    Linux中安装Flash,可通过Adobe官网下载适用于Linux的Flash Player安装包

    2025年8月14日
    1400
  • 禁用IPv6能解决服务器问题?

    为什么需要启用 IPv6?IPv6 是下一代互联网协议,解决了 IPv4 地址枯竭问题,提供更大的地址空间(如 2001:db8::1)、更高的安全性和效率,随着全球 IPv4 地址耗尽,启用 IPv6 已成为网络优化的关键步骤,本指南将详细介绍在 Linux 系统中启用 IPv6 的方法,检查当前 IPv6……

    2025年6月23日
    3400
  • 如何用Linux复制命令让效率翻倍?

    核心命令:cp(复制文件/目录)基本语法:cp [选项] 源文件 目标路径常用选项:选项作用示例-r递归复制目录(必需)cp -r dir1/ dir2/-i覆盖前提示确认(防误删)cp -i file.txt backup/-v显示复制详情(可视化过程)cp -v *.jpg /photos/-u仅复制更新的……

    2025年7月25日
    2800
  • 如何快速确认系统并进行基础操作?

    在开始使用前,请务必确认您的系统版本,主流 Linux 发行版(如 Red Hat Enterprise Linux / CentOS)的 1 版本发布于 2015 年,目前已结束生命周期(EOL),不再获得安全更新和技术支持,强烈建议用户升级至受支持的版本(如 RHEL/CentOS 8+ 或 Ubuntu……

    2025年7月4日
    3700
  • 如何显示linux下的用户

    Linux下,可使用cat /etc/passwd查看所有用户信息,或用

    2025年8月13日
    1400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信