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
    • 最新
    • 标签
主页 / server / 问题 / 1148960
Accepted
user2690527
user2690527
Asked: 2023-12-02 02:45:10 +0800 CST2023-12-02 02:45:10 +0800 CST 2023-12-02 02:45:10 +0800 CST

如何确保 root fs 可写后启动 system-userdbd.service 而不创建循环依赖?

  • 772

我有一个快速虚拟机,但 systemd 服务systemd-zserdbd.service失败并显示

Dec 01 17:45:32 server-new systemd[1]: Starting systemd-remount-fs.service...

...

Dec 01 17:45:32 server-new (-userdbd)[183]: systemd-userdbd.service: Failed at step NAMESPACE spawning /usr/lib/systemd/systemd-userdbd: Read-only file system
Dec 01 17:45:32 server-new (-userdbd)[185]: systemd-userdbd.service: Failed at step NAMESPACE spawning /usr/lib/systemd/systemd-userdbd: Read-only file system
Dec 01 17:45:32 server-new systemd[1]: Started systemd-journald.service.
Dec 01 17:45:32 server-new (-userdbd)[186]: systemd-userdbd.service: Failed at step NAMESPACE spawning /usr/lib/systemd/systemd-userdbd: Read-only file system
Dec 01 17:45:32 server-new (-userdbd)[187]: systemd-userdbd.service: Failed at step NAMESPACE spawning /usr/lib/systemd/systemd-userdbd: Read-only file system
Dec 01 17:45:32 server-new (-userdbd)[188]: systemd-userdbd.service: Failed at step NAMESPACE spawning /usr/lib/systemd/systemd-userdbd: Read-only file system

...

Dec 01 17:45:32 server-new systemd-fsck[180]: /usr/bin/fsck.xfs: XFS file system.
Dec 01 17:45:32 server-new systemd[1]: Finished systemd-remount-fs.service.

...

Dec 01 17:45:32 server-new systemd[1]: Reached target local-fs-pre.target.

...

Dec 01 17:45:33 server-new systemd[1]: Reached target local-fs.target.

该错误非常明显:systemd-userdbd.service需要可写的根文件系统,但在文件系统重新挂载为可写之前启动。

systemctl edit systemd-userdbd.service --drop-in=wait-for-rw-root因此,我想通过with添加必要的依赖项

[Unit]
Wants=local-fs.target
After=systemd-userdbd.socket systemd-remount-fs.service local-fs.target

但这似乎在启动时创建了循环依赖。重新挂载文件系统需要很长时间,直到 systemd 超时。

  1. 如何确保systemd-userdbd.service在根文件系统变得可写后启动而不创建循环依赖?
  2. (一个更普遍的问题)我如何分析造成循环依赖的原因?
systemd
  • 2 2 个回答
  • 52 Views

2 个回答

  • Voted
  1. u1686_grawity
    2023-12-06T03:12:10+08:002023-12-06T03:12:10+08:00

    如何确保在根文件系统变得可写后启动 systemd-userdbd.service,而不创建循环依赖项?

    让您的 initramfs (或内核)立即将文件系统挂载为读写,而无需经历“ro-fsck-remount-rw”舞蹈。也就是说,使用rw内核选项而不是ro.

    (通常第一步是确保您的 initramfs 中包含“fsck”,但在您的情况下,“fsck.xfs”除了打印消息之外实际上不执行任何其他操作,因此没有它您也可以正常工作。)

    (一个更普遍的问题)我如何分析造成循环依赖的原因?

    systemctl list-dependencies --after应该显示它。

    Systemd 会将排序循环的每个组成部分打印到日志中。以 root 身份登录并检查journalctl -b“ deleted to break ordering cycle”。

    • 0
  2. Best Answer
    user2690527
    2023-12-07T04:18:06+08:002023-12-07T04:18:06+08:00

    我终于自己找到了解决方案。systemd-userdbd.socket触发器systemd-userdbd.service。因此,解决方案是添加额外的依赖项systemd-userdbd.socket,延迟套接字的启动,进而延迟相应的服务。

    systemctl edit systemd-userdbd.socket --drop-in=wait-for-rw-root我创建了一个包含以下内容的插入式via

    [Unit]
    After=systemd-remount-fs.service local-fs.target
    Wants=local-fs.target
    

    但基本上这是一个上游错误,因为该服务需要可写的根文件系统,但未能将其添加到其必需条件中。

    • 0

相关问题

  • After= 选项在 systemd 服务文件中不起作用

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve