为什么 bash 参数扩展在 systemd 服务文件中不起作用?

为什么 bash 参数扩展在 systemd 服务文件中不起作用?

我正在尝试使用systemd'sEnvironmentFile并在文件中设置命令时向该命令添加一个选项。我的单元文件中有以下内容:

ExecStart=/usr/bin/bash -c "echo ${PORT:+port is $PORT}"

当我启动服务时,它不会回显任何内容。

以下内容按预期工作:

ExecStart=/usr/bin/bash -c "echo port is $PORT"

这意味着文件被正确读取。

参数替换也适用于命令行:

$ PORT=1234 bash -c 'echo ${PORT:+port is $PORT}'
port is 1234

我缺少什么?

答案1

systemd 进行自己的简约 shell 式命令行解析的内容ExecStart=和其他参数。这种简约的解析支持基本的环境变量替换,但显然不支持${PORT:+port is $PORT}.

您将希望阻止 systemd 执行此操作并让调用的 shell 处理它。

从文档中:

要传递字面美元符号,请使用“ $$”。

所以试试这个:

ExecStart=/usr/bin/bash -c "echo $${PORT:+port is $$PORT}"

或者更好的是,试试这个:

ExecStart=/bin/sh -c "echo $${PORT:+port is $$PORT}"

因为您在这里执行的变量扩展类型是 POSIX 标准,而不是 bash-ism。通过使用/bin/sh代替,bash您将消除对 的不必要的依赖bash

相关内容