AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 408936
Accepted
x-yuri
x-yuri
Asked: 2017-12-06 05:51:01 +0800 CST2017-12-06 05:51:01 +0800 CST 2017-12-06 05:51:01 +0800 CST

为什么 `journalctl --list-boots` 与 `uptime` 和 `who -b` 报告的不匹配?

  • 772

这是我使用的测试脚本:

last_reboot=$(last reboot | grep 'still running' | awk '{for (i=5; i<=NF; i++) printf $i FS}' | awk '{for (i=1; i<=NF - 2; i++) printf $i FS}')
if [ "$last_reboot" ]; then
    date -d "$last_reboot" '+last reboot: %Y-%m-%d'
fi

days=$(uptime | awk '{print $3}')
hours=$(uptime | awk '{print $5}' | sed -E 's/,$//')
h=$(echo "$hours" | cut -d: -f 1)
m=$(echo "$hours" | cut -d: -f 2)
date -d "- $days days - $h hours - $m minutes" '+uptime: %Y-%m-%d'

who -b | awk '{print "who: " $3}'

journalctl --list-boots | awk '$1 == "0" {print "journalctl: " $4}'

在本地,所有四个日期都匹配。

我在大约 10 台服务器上运行它。last reboot不报告任何内容(可能是因为wtmp被 旋转logrotate)。uptime和who -b匹配。而journalctl没有。究竟journalctl --list-boots报告了什么?为什么它不能匹配其他工具报告的内容?

systemd boot
  • 1 1 个回答
  • 6276 Views

1 个回答

  • Voted
  1. Best Answer
    JdeBP
    2017-12-06T13:08:12+08:002017-12-06T13:08:12+08:00

    Linux 操作系统上的新二进制日志不像旧的二进制日志那样工作。

    旧的二进制日志是/var/log/wtmp和/var/log/btmp. 在系统引导时,将wtmp使用用户名写入reboot条目,在关闭时将wtmp使用用户名写入条目shutdown。查找系统重新启动的时间是使用last rebootandlast shutdown命令打印出这些条目的问题。

    新的二进制日志是 systemd 日志,它们没有这样的条目。

    相反,每条日志记录都有一个名为boot ID的字段。-o verbose您可以通过选项来查看此内容journalctl。引导 ID 由内核在引导时生成,并将systemd-journald从内核获取的当前引导 ID 应用于每个日志记录,因为它正在将其添加到日志中。

    为了实现该list-boots功能,journalctl扫描整个日志,读取每条记录的时间戳和引导 ID ,并记录与每个唯一引导 ID 相关联的最早和最新时间​​戳。

    因此,如果日志的某些部分被清除,或者相反地停留时间过长,则报告的明显启动和关闭时间journalctl将与实际的启动和关闭时间大不相同。

    /run/utmp是一个终端登录记录表,带有用于启动和关闭的特殊条目。这些条目由uptime和读取who -b。它们是由systemd-update-utmp类似 FreeBSDutx命令的程序编写的,它们作为启动和关闭过程的一部分运行。它们不是最先或最后运行的,因为相关服务不是(并且实际上不能)绝对首先或最后订购。在运行时间之前可能存在具有相关引导 ID 的systemd-update-utmp reboot日志条目,以及在运行时间之后的类似日志条目systemd-update-utmp shutdown。

    进一步阅读

    • https://unix.stackexchange.com/a/383575/5132
    • https://unix.stackexchange.com/a/294206/5132
    • 4

相关问题

  • 系统完好,grub坏了

  • 使用 systemd 看门狗支持重新启动应用程序

  • “pacman -Syu”“可能”破坏了我的系统,因为未安装引导

  • 克隆的 SSD 无法启动并打印奇怪的线条

  • 使用键盘快捷键启动/停止 systemd 服务 [关闭]

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    JSON数组使用jq来bash变量

    • 4 个回答
  • Marko Smith

    日期可以为 GMT 时区格式化当前时间吗?[复制]

    • 2 个回答
  • Marko Smith

    bash + 通过 bash 脚本从文件中读取变量和值

    • 4 个回答
  • Marko Smith

    如何复制目录并在同一命令中重命名它?

    • 4 个回答
  • Marko Smith

    ssh 连接。X11 连接因身份验证错误而被拒绝

    • 3 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Marko Smith

    systemctl 命令在 RHEL 6 中不起作用

    • 3 个回答
  • Marko Smith

    rsync 端口 22 和 873 使用

    • 2 个回答
  • Marko Smith

    以 100% 的利用率捕捉 /dev/loop -- 没有可用空间

    • 1 个回答
  • Marko Smith

    jq 打印子对象中所有的键和值

    • 2 个回答
  • Martin Hope
    EHerman JSON数组使用jq来bash变量 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux 日期可以为 GMT 时区格式化当前时间吗?[复制] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC 如何复制目录并在同一命令中重命名它? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve “root”用户的文件权限如何工作? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe 将默认编辑器更改为 vim for _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey 如何下载软件包而不是使用 apt-get 命令安装它? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao 为什么目录 /home、/usr、/var 等都具有相同的 inode 编号 (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg —list-keys 命令在将私钥导入全新安装后输出 uid [未知] 2017-11-26 18:26:02 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve