系统脚本失败



我想在 Debian 9 盒子里运行一个系统启动的脚本。我的脚本在独立运行时工作,但在 systemd 下失败。

我的脚本只是将备份文件从远程服务器复制到本地计算机:

#!/bin/sh
set -e
/usr/bin/sshpass -p "PASSWORD" /usr/bin/scp -p USER@10.0.0.2:ORIGINPATH/backupserver.zip DESTINATIONPATH/backupserver/

只是为了隐私,我替换了上面的密码,用户和路径。

我编写了以下 systemd 服务单元:

[Unit]
Description=backup script
[Service]
Type=oneshot
ExecStart=PATH/backup.sh
[Install]
WantedBy=default.target

然后我为脚本设置权限:

chmod 744 PATH/backup.sh

并安装了该服务:

chmod 664 /etc/systemd/system/backup.service
systemctl daemon-reload
systemctl enable backup.service

重新启动脚本时脚本失败:

● backup.service - backup script
   Loaded: loaded (/etc/systemd/system/backup.service; enabled; vendor preset: enabled)
   Active: failed (Result: exit-code) since Sat 2017-05-13 13:39:54 -03; 47min ago
 Main PID: 591 (code=exited, status=1/FAILURE)

日志 -xe 的结果:

mai 16 23:34:27 rodrigo-acer systemd[1]: backup.service: Main process exited, code=exited, status=6/NOTCONFIGURED
mai 16 23:34:27 rodrigo-acer systemd[1]: Failed to start backup script.
mai 16 23:34:27 rodrigo-acer systemd[1]: backup.service: Unit entered failed state.
mai 16 23:34:27 rodrigo-acer systemd[1]: backup.service: Failed with result 'exit-code'.

可能出了什么问题?

解决了伙计们。有2个问题:

1 - 我必须更改服务单元文件,以使服务仅在网络启动后运行。单位部分更改为:

 [Unit]
 Description = World server backup
 Wants = network-online.target
 After = network.target network-online.target

2 - root 用户没有将远程主机添加到已知主机列表中,这与我用来测试脚本的普通用户不同。

失败,

结果为"退出代码" 您可以在最后一行尝试:

# REQUIRED FOR SYSTEMD: 0 means clean no error
exit 0

您可能还需要添加:

Type=forking

到 systemd 条目,类似于: https://serverfault.com/questions/751030/systemd-ignores-return-code-while-starting-service

如果您的服务或脚本没有分叉,请在末尾添加 &以在后台运行它,并以 0 快速退出。否则,它将像一个超时并永远需要/看起来像冻结服务的初创公司一样。