在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)
酷番叔酷番叔
上一篇 2025年9月9日 13:39
下一篇 2025年9月9日 13:53

相关推荐

  • Arch Linux如何打开终端?

    在Arch Linux系统中,终端(Terminal)是与系统交互的核心工具,无论是命令操作、软件安装还是系统管理,都离不开终端的使用,掌握多种打开终端的方法,能根据不同场景灵活提升操作效率,以下是Arch Linux中打开终端的详细方法,涵盖图形界面、命令行及快捷操作等多种途径,通过图形界面应用程序菜单打开如……

    2025年9月23日
    7100
  • Linux系统如何在局域网内详细实现文件共享?方法有哪些?

    在Linux系统中,共享文件是常见的网络需求,无论是企业环境中的跨平台协作,还是家庭网络内的文件互通,都需要高效的共享方案,Linux提供了多种文件共享协议和服务,支持不同场景下的文件传输与访问需求,本文将详细介绍主流的Linux文件共享方法,包括Samba(与Windows共享)、NFS(Linux/Unix……

    2025年9月21日
    7400
  • 如何在Linux安装并配置FTP服务器?

    在Linux系统中搭建FTP服务器是许多企业和个人用户的需求,FTP(文件传输协议)用于在客户端和服务器之间进行文件传输,尤其适合需要频繁上传下载文件的场景,本文将以常用的vsftpd(Very Secure FTP Daemon)为例,详细介绍在Linux系统上安装、配置FTP服务器的完整步骤,包括安装软件包……

    2025年9月16日
    8700
  • linux下如何搭建ftp

    Linux 下可安装 vsftpd,编辑配置文件设置用户权限等

    2025年8月9日
    9700
  • 如何理解文件权限rw-r-r-1?

    权限基础概念Linux为每个文件/目录定义三类用户:所有者(Owner):文件创建者或指定用户所属组(Group):共享权限的用户组其他用户(Others):系统所有其他账户权限类型分为三种:读(r):查看文件内容/目录列表写(w):修改文件/在目录增删文件执行(x):运行程序/进入目录查看当前权限使用 ls……

    2025年7月12日
    10000

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信