AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 1089704
Accepted
Jesper.Lindberg
Jesper.Lindberg
Asked: 2018-11-04 03:38:58 +0800 CST2018-11-04 03:38:58 +0800 CST 2018-11-04 03:38:58 +0800 CST

无法在启动时启动服务 noip2 [重复]

  • 772
这个问题在这里已经有了答案:
如何将 No-IP 设置为适当的服务? (2 个回答)
3年前关闭。

我按照本指南安装了 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.
server startup dns
  • 1 1 个回答
  • 19972 Views

1 个回答

  • Voted
  1. Best Answer
    PerlDuck
    2018-11-04T11:08:51+08:002018-11-04T11:08:51+08:00

    从 Ubuntu 15.04 开始,控制后台进程(以及更多)的标准方法是systemd. 我建议从你的init.d脚本切换到一个systemd 单元:

    /etc/systemd/system/noip2.service使用以下内容创建文件(并删除您的init.d脚本):

    [Unit]
    Description=noip2 service
    
    [Service]
    Type=forking
    ExecStart=/usr/local/bin/noip2
    Restart=always
    
    [Install]
    WantedBy=default.target
    

    然后发出

    sudo systemctl daemon-reload
    

    了解systemd新单元(systemd缓存单元文件,此命令systemd重新考虑其缓存)。

    现在您可以尝试启动和停止您的设备并查看其状态:

    sudo systemctl status noip2
    sudo systemctl start  noip2
    sudo systemctl status noip2
    sudo systemctl stop   noip2
    sudo systemctl status noip2
    

    要让设备在引导时启动,您需要启用它:

    sudo systemctl enable noip2
    

    要在引导时禁用自动启动,您必须禁用该单元:

    sudo systemctl disable noip2
    

    大多数时候,五个命令足以控制一个单位的行为:

    systemctl start   $unit   # starts a unit NOW
    systemctl stop    $unit   # stops a unit NOW
    systemctl status  $unit   # shows status
    systemctl enable  $unit   # starts a unit at boot time (but not NOW)
    systemctl disable $unit   # stops autostart (but doesn't stop the unit NOW)
    

    您还可以启用自动启动并立即启动设备或禁用自动启动并立即停止它:

    systemctl enable  --now $unit   # enable and start in one go
    systemctl disable --now $unit   # disable and stop in one go
    

    更新

    一些研究显示noip2作为守护进程运行,即当您启动它时,它会创建另一个在后台运行的进程(所谓的分叉),而前台进程会立即返回(退出)。这就是 init.d 脚本和 systemd 单元失败的原因:他们开始noip2只是为了看到它立即退出。因此,systemd 试图一遍又一遍地重新启动它,但无济于事。(默认情况下,systemd 在 10 秒左右内最多重启 5 次进程,然后放弃并使其处于失败状态。)

    要告诉 systemd 该单元是分叉类型,请添加以下行

    Type=forking
    

    [Service]就像我在上面的片段中所做的那样。这告诉 systemd期望主进程立即返回,而是观察由noip2.

    • 22

相关问题

  • 如何从命令行刻录双层 dvd iso

  • 遇到网络问题时,如何让 Empathy 重试连接

  • 如果在服务器机器上运行 Ubuntu 桌面版,性能损失是多少?

  • 将桌面版剥离为服务器版的最简单方法是什么?

  • 如何与无头服务器进行图形交互?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve