Centos7 捕获关机信息
时间: 2024-02-02 10:03:49 浏览: 85
要捕获 CentOS 7 的关机信息,可以尝试以下步骤:
1. 打开终端并切换到 root 用户。
2. 执行命令 `journalctl -b -1`,它将显示上一次启动的所有日志信息。
3. 搜索关机信息,可以使用命令 `grep "systemd-shutdown" -B 1 /var/log/messages`。
4. 如果想要持久化记录关机信息,可以编辑 `/etc/systemd/journald.conf` 文件,修改 `Storage` 选项为 `persistent`,然后重启 `systemd-journald` 服务。
这样就可以捕获 CentOS 7 的关机信息了。
相关问题
如Centos 7 如何捕获关机时的系统运行级别
在 CentOS 7 中,可以通过 systemd 服务管理器来捕获系统运行级别。systemd 提供了一个名为 systemd-halt.service 的服务,它会在系统关机时执行。
为了捕获系统运行级别,可以在 systemd-halt.service 的 ExecStop 部分添加以下命令:
```
systemctl status --no-pager | grep "Main PID" | awk '{print $3}' > /var/run/shutdown.pid
```
这个命令会查询系统当前运行的服务,并将包含 "Main PID" 的行的第三个字段(即 systemd 进程的 PID)写入 /var/run/shutdown.pid 文件中。
当系统关机时,systemd-halt.service 将会执行这个命令,并将当前 systemd 进程的 PID 写入到 /var/run/shutdown.pid 文件中。这个文件可以在系统启动时被读取,以确定系统关机时的运行级别。
在启动脚本中,可以通过读取 /var/run/shutdown.pid 文件来获取系统关机时的运行级别。例如,可以使用以下命令来读取 /var/run/shutdown.pid 文件:
```
if [ -f /var/run/shutdown.pid ]; then
shutdown_pid=$(cat /var/run/shutdown.pid)
# Do something with the shutdown PID
fi
```
这个命令会检查 /var/run/shutdown.pid 文件是否存在,并将其中的 PID 赋值给变量 shutdown_pid。然后,可以根据 shutdown_pid 变量的值来确定系统关机时的运行级别。
Centos7 修改systemd-halt.service 捕获关机系统运行级别
明白了,你想要修改 `systemd-halt.service` 来捕获关机时的系统运行级别。
首先,你需要编辑 `/usr/lib/systemd/system/systemd-halt.service` 文件,可以使用以下命令打开文件:
```
sudo vi /usr/lib/systemd/system/systemd-halt.service
```
在该文件中,你需要找到以下行:
```
ExecStart=/usr/bin/systemctl halt
```
将其替换为以下两行:
```
ExecStart=/usr/bin/logger -t "systemd-halt" "System is powering off, current runlevel: $(runlevel)"
ExecStart=/usr/bin/systemctl halt
```
这将在关机时使用 `logger` 命令记录当前运行级别,并将其输出到系统日志中。你可以使用 `journalctl` 命令查看日志,例如:
```
sudo journalctl -u systemd-halt
```
这样就完成了修改,保存文件并退出编辑器。然后,重新加载 systemd 配置:
```
sudo systemctl daemon-reload
```
现在,当你关机时,系统日志将记录当前的运行级别。
阅读全文