在 Ubuntu 22.04 服务器上,我有一个用于重新加载 nagios4 配置的 bash 脚本。重新加载后,我想检查服务是否正常
#!/bin/bash
sudo systemctl reload nagios4.service
if (systemctl --quiet is-failed nagios4.service); then
echo "Bad config!"
fi
不知何故它不工作,如果配置不正确,服务就会失败,但无法被识别systemctl is-failed
如果我手动检查systemctl status nagios4
× nagios4.service - nagios4
Loaded: loaded (/lib/systemd/system/nagios4.service; enabled; vendor preset: enabled)
Active: failed (Result: exit-code) since Wed 2024-06-05 09:20:03 CEST; 4min 27s ago
我曾尝试将我的脚本改为使用restart
而不是reload
或使用 来运行systemctl is-failed
,sudo
但没有任何变化。
我错过了什么?
更新:即使失败也会reload
返回状态0
sudo systemctl reload nagios4.service
status=$?
echo $status
reload 命令会向服务发送信号,要求其重新加载配置,而无需重新启动整个服务。如果由于配置不当导致重新加载失败,服务可能不会立即转换为 systemctl is-failed 可以检测到的“失败”状态。
一种可靠的方法是在重新加载后直接检查服务的状态,而不是依赖重新加载命令本身的退出状态。以下是您可以如何调整脚本:
首先不要使用外部脚本来检查 systemd 状态,而是使用 systemd 在某些状态下运行脚本。
这里有很多关于如何使用
OnFailure
等的有用示例:https://unix.stackexchange.com/questions/441575/proper-way-to-use-onfailure-in-systemd