我按照本指南安装了 no-ip 动态 ddns: https ://www.noip.com/support/knowledgebase/installing-the-linux-dynamic-update-client/
我让服务运行
sudo /usr/local/bin/noip2
但是我希望服务在启动时启动,我尝试将以下脚本添加到 /etc/init.d/noip2.sh
#######################################################
#! /bin/sh
# . /etc/rc.d/init.d/functions # uncomment/modify for your killproc
case "$1" in
start)
echo "Starting noip2."
/usr/local/bin/noip2
;;
stop)
echo -n "Shutting down noip2."
killproc -TERM /usr/local/bin/noip2
;;
*)
echo "Usage: $0 {start|stop}"
exit 1
esac
exit 0
#######################################################
其次是:
sudo chmod +x /etc/init.d/noip2.sh
sudo update-rc.d noip2.sh defaults
现在我应该可以启动服务了
sudo service noip2 start
但我不是。当我运行时,journalctl -xe
我得到以下信息:
-- Unit noip2.service has begun starting up.
Nov 03 12:36:11 media systemd[3111]: noip2.service: Failed to execute command: Exec format error
Nov 03 12:36:11 media systemd[3111]: noip2.service: Failed at step EXEC spawning /etc/init.d/noip2.sh: Exec format error
-- Subject: Process /etc/init.d/noip2.sh could not be executed
-- Defined-By: systemd
-- Support: http://www.ubuntu.com/support
--
-- The process /etc/init.d/noip2.sh could not be executed and failed.
--
-- The error number returned by this process is 8.
Nov 03 12:36:11 media systemd[1]: noip2.service: Control process exited, code=exited status=203
Nov 03 12:36:11 media systemd[1]: noip2.service: Failed with result 'exit-code'.
Nov 03 12:36:11 media systemd[1]: Failed to start noip2.service.
-- Subject: Unit noip2.service has failed
-- Defined-By: systemd
-- Support: http://www.ubuntu.com/support
用户 PerDuck 的更新信息:尝试您的解决方案时出现以下错误... :( 尝试添加
RestartSec=30
至少它现在一直在尝试,但仍然没有开始。我仍然可以使用 sudo /usr/local/bin/noip2 启动它
错误:
Nov 03 23:26:42 media systemd[1]: noip2.service: Service hold-off time over, scheduling restart.
Nov 03 23:26:42 media systemd[1]: noip2.service: Scheduled restart job, restart counter is at 5.
Nov 03 23:26:42 media systemd[1]: Stopped noip2 service.
Nov 03 23:26:42 media systemd[1]: noip2.service: Start request repeated too quickly.
Nov 03 23:26:42 media systemd[1]: noip2.service: Failed with result 'start-limit-hit'.
Nov 03 23:26:42 media systemd[1]: Failed to start noip2 service.
从 Ubuntu 15.04 开始,控制后台进程(以及更多)的标准方法是
systemd
. 我建议从你的init.d
脚本切换到一个systemd
单元:/etc/systemd/system/noip2.service
使用以下内容创建文件(并删除您的init.d
脚本):然后发出
了解
systemd
新单元(systemd
缓存单元文件,此命令systemd
重新考虑其缓存)。现在您可以尝试启动和停止您的设备并查看其状态:
要让设备在引导时启动,您需要启用它:
要在引导时禁用自动启动,您必须禁用该单元:
大多数时候,五个命令足以控制一个单位的行为:
您还可以启用自动启动并立即启动设备或禁用自动启动并立即停止它:
更新
一些研究显示
noip2
作为守护进程运行,即当您启动它时,它会创建另一个在后台运行的进程(所谓的分叉),而前台进程会立即返回(退出)。这就是 init.d 脚本和 systemd 单元失败的原因:他们开始noip2
只是为了看到它立即退出。因此,systemd 试图一遍又一遍地重新启动它,但无济于事。(默认情况下,systemd 在 10 秒左右内最多重启 5 次进程,然后放弃并使其处于失败状态。)要告诉 systemd 该单元是分叉类型,请添加以下行
[Service]
就像我在上面的片段中所做的那样。这告诉 systemd期望主进程立即返回,而是观察由noip2
.