Arch manual pages

SYSTEMD-NOTIFY(1) systemd-notify SYSTEMD-NOTIFY(1)

NAME

systemd-notify - 向 systemd 报告服务状态的变化

SYNOPSIS

systemd-notify [OPTIONS...] [VARIABLE=VALUE...]

描述

systemd-notify 可用于 在守护进程脚本中向 systemd 报告进程状态的变化。 可用于发送任意信息, 其中最重要的是 报告"启动已完成"的消息。
此工具基本上就是对 sd_notify() 的简单包装, 以便于在脚本中使用。详见 sd_notify(3) 手册。
注意,在报告状态更新的同时, 还可以传递一系列环境变量。
注意, 除非在调用此命令的服务单元中设置了 NotifyAccess=all , 否则 systemd 将会拒绝接受状态更新的消息。

选项

能够识别的命令行选项如下:
--ready
向 systemd 报告"启动已完成"的消息。 这等价于 systemd-notify READY=1 。 详见 sd_notify(3) 手册。
--pid=
向 systemd 报告主守护进程的 PID 。 如果 PID 参数被省略, 将使用调用 systemd-notify 的进程的 PID 。 这等价于 systemd-notify MAINPID=$PID 。 详见 sd_notify(3) 手册。
--status=
向 systemd 发送一个任意内容的字符串消息。 这等价于 systemd-notify STATUS=... 。 详见 sd_notify(3) 手册。
--booted
用于检查系统的 init 进程是否为 systemd , 返回 0 表示系统的 init 进程是 systemd ,返回非零表示其他。 此选项并不发送任何消息,因此与其他选项没有任何关系。 详见 sd_booted(3) 手册。 另一种检查方法是 systemctl(1)is-system-running 命令。 若返回 "offline" 则表示系统的 init 进程不是 systemd
-h, --help
显示简短的帮助信息并退出。
--version
显示简短的版本信息并退出。

退出状态

返回值为 0 表示成功, 非零返回值表示失败代码。

例子

Example 1. 启动通知与状态更新
一个简单的守护进程脚本,在创建好通信管道之后, 向 systemd 报告"启动已完成"的消息。在运行时, 向 systemd 报告更多的状态消息:
 
#!/bin/bash
mkfifo /tmp/waldo systemd-notify --ready --status="Waiting for data..."
while : ; do read a < /tmp/waldo systemd-notify --status="Processing $a"
# Do something with $a ...
systemd-notify --status="Waiting for data..." done

参见

systemd(1), systemctl(1), systemd.unit(5), sd_notify(3), sd_booted(3)

本页面中文版由中文 man 手册页计划提供。
翻译人员:金步国
 
金步国作品集:http://www.jinbuguo.com
 
 
中文 man 手册页计划: https://github.com/man-pages-zh/manpages-zh
systemd 231