我有一个用 go
编写的小程序,它使用 go-systemd 库通过 dbus 与 systemd 交互。
程序本身注册为 systemd 单元并应在引导时启动。程序运行时,会定期查询多个单元的systemd单元状态。
现在当我手动启动程序时,一切都很好。然而,当 systemd 重新启动后启动时,它将“挂起”,这意味着它将无法通过 dbus 查询 systemd 单元状态。我将从 go-systemd
库收到以下消息:
process org.freedesktop.systemd1 exited with status 1
现在,当我重新启动程序时,它将立即能够毫无错误地查询 systemd 单元。这导致我假设我的程序存在错误/配置错误的依赖项,因此在启动时会出现竞争条件,导致程序无法通过 dbus 与 systemd 进行通信。
现在我已经把这个和其他几个组合放在一起了,但是它没有帮助:
Requires=dbus.service After=dbus.service Wants=org.freedesktop.systemd1
我需要如何配置我自己的 systemd 单元(go 程序的),以便它能够在重新启动后立即通过 dbus 与 systemd 进行通信?我必须配置什么依赖项?
听起来您的程序默认情况下正在尝试连接到 DBus Session 总线,因为您说手动运行它时它工作正常。当应用程序从 Systemd 启动时,默认情况下它将以 root 身份运行,没有可连接的会话总线,因此它将失败。
当用户在图形终端上登录时,会话总线通常在每次登录的基础上启动。在终端登录时默认不会启动。
如果是这种情况,我目前可以看到您有两个选择:
dbus-launch
创建您的应用程序可以连接到的新总线。