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
    • 最新
    • 标签
主页 / unix / 问题 / 781791
Accepted
Guaiacol
Guaiacol
Asked: 2024-08-12 20:57:15 +0800 CST2024-08-12 20:57:15 +0800 CST 2024-08-12 20:57:15 +0800 CST

Systemctl 单元在“Requisite”上失败,但仍执行“ExecStart”命令

  • 772

我正在尝试创建一个 systemctl 单元,只有当另一个单元处于活动状态时,该单元才会启动。据我所知,可以通过指定一个Requisite字段来完成。因此,我已按如下方式配置我的单元:

[Unit]
Description=Force clients with mismatching IPs to reconnect
[email protected]

[Service]
Type=oneshot
ExecStart=/etc/openvpn/kicker/kicker.py
TimeoutSec=15

但是,当我使用systemctl stop openvpn@server和时systemctl start my-unit,我收到以下日志:

Starting openvpn-kicker.service - Force clients with mismatching IPs to reconnect...
Dependency failed for openvpn-kicker.service - Force clients with mismatching IPs to reconnect.
openvpn-kicker.service: Job openvpn-kicker.service/start failed with result 'dependency'.
kicker.py[1026]: Traceback (most recent call last):
kicker.py[1026]:   File "/etc/openvpn/kicker/kicker.py", line 16, in <module>
kicker.py[1026]:     manage.connect(Manage_Path)
kicker.py[1026]: FileNotFoundError: [Errno 2] No such file or directory
Main process exited, code=exited, status=1/FAILURE
openvpn-kicker.service: Failed with result 'exit-code'.

因此,基本上,单元在需求检查时失败,但无论如何都会在“ExecStart”中执行脚本 - 因此出现 python 错误。它是否打算以这种方式工作,而我弄错了什么,或者这是一个错误?如果相关,操作系统是 Ubuntu 22.04

systemctl
  • 1 1 个回答
  • 25 Views

1 个回答

  • Voted
  1. Best Answer
    muru
    2024-08-13T00:00:31+08:002024-08-13T00:00:31+08:00

    首先,请注意,在 systemd 中,需求依赖关系和顺序依赖关系是正交的。一个单元可以对另一个单元有弱/中等/强需求(Wants、Requires、Requisite等),但顺序必须使用Before/单独指定After。可以这样想:

    • Wants=foo:当我开始时,foo也要求开始,但我并不真正关心它会发生什么。
    • Requires=foo:当我启动时,foo也请求启动,如果foo的启动失败,则认为我的启动也失败,而不管对我的启动所采取的实际操作的状态如何。
    • Requisite=foo:当我启动时,foo必须已经启动。如果没有,则认为我的启动失败,无论对我的启动采取的实际操作的状态如何。

    因此,我可以拥有服务 A 和RequiresB,但可能有 B 的排序Before。当 B 正在做一些可以独立于 A 完成的一般性事情时,可能会出现这种情况,但 A 总是希望 B 在 A 启动后再做那件事。

    特别是对于Requisite,文档特别建议将其与以下一起使用After:

    因此此设置通常应与 结合使用After=,以确保该单元不会先于其他单元启动。

    第二件要理解的事情是,作业和单元在 systemd 中是独立但相关的概念。有关更多信息,请参阅例如此答案或此答案。因此,当文档说:

    然而,如果这里列出的单元尚未启动,它们将不会被启动,并且该单元的启动将立即失败。

    这意味着该单元的启动工作将失败。但实际启动将继续进行。其工作方式如下:

    1. 您运行systemctl start foo,或者其他导致foo启动的操作(例如,另一个单元、目标等的依赖)。
    2. 然后 systemd 创建一个作业来启动该单元。
      1. 它向依赖单元发出有关其状态的查询。
      2. Requisite[在 (5) 之前的某个时间] 对非活动单元的查询导致作业状态设置为失败。
    3. Systemd 等待任何按Before顺序排列的单元的作业。
    4. 如果排序中没有任何内容失败(即Required或Requisite更严重),则它将继续实际运行ExecStart*命令。请注意,这意味着如果排序中它之前没有其他作业,则systemd 将立即继续执行此步骤。
    5. 它报告作业的状态。
      1. Requisite如果某个单元未处于活动状态或者由于其他一系列原因(例如实际运行命令失败等),此操作将会失败。

    为了使 (2.1) 中的检查对 (4) 中的命令执行有任何意义,systemd 应该在 (3) 中考虑一个顺序。在本例中,没有。

    引用Lennart Poettering 的话:

    没有 After= 的 Requisite= 是没有意义的。您将检查排入队列以确保某个单元已正确启动,但随后不等待检查结果,而是允许您放置该单元立即启动……

    • 2

相关问题

  • 如何从自动启动中删除服务?

  • 显示服务重新启动时的日志日志

  • Systemctl 重启服务触发另一个命令

  • 根据日志输出关键字重启服务

  • 为什么 systemctl halt 要求输入密码但 systemctl reboot 和 systemctl poweroff 没有?

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve