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 / 问题 / 684209
Accepted
mprudek
mprudek
Asked: 2021-12-29 11:34:24 +0800 CST2021-12-29 11:34:24 +0800 CST 2021-12-29 11:34:24 +0800 CST

无法在 Debian 11 Bullseye 上自动启动非特权 LXC 容器

  • 772

lxc-autostart不会在 Debian 11 Bullseye 中启动非特权容器。

Debian 11 Bullseye 中非特权容器的启动 通过使用代替解决了这个答案,但我在使用.lxc-unpriv-startlxc-startlxc-autostart

debian lxc
  • 2 2 个回答
  • 551 Views

2 个回答

  • Voted
  1. Best Answer
    mprudek
    2021-12-31T09:04:08+08:002021-12-31T09:04:08+08:00

    基本解决方案

    好的,经过几个不眠之夜,我最终为每个容器创建了一个简单的 systemd 单元文件。一个示例可能如下所示:

    [Unit]
    Description=Linux container my-container-name
    After=network.target
    
    [Service]
    Type=forking
    ExecStart=/usr/bin/lxc-start -n my-container-name
    ExecStop=/usr/bin/lxc-stop -n my-container-name
    StandardOutput=journal
    User=my-lxc-user
    Group=my-lxc-user
    Delegate=yes
    
    [Install]
    WantedBy=multi-user.target
    

    这是对此处发布的建议以及我在上面已经链接的答案Delegate=yes中的简单跟进。

    不需要用户逗留(此处提到)。

    这个解决方案的一个很好的副作用是关闭(非特权)容器不再延迟主机关闭(如此处所述),因为使用/usr/bin/lxc-stop -n my-container-name定义ExecStop而不是发送信号。

    调优 - Systemd 模板

    感谢systemd 模板单元文件,可以对所有容器使用单个 unif 文件。我的最终模板单元文件如下所示:

    [Unit]
    Description=Linux container %I
    After=network.target
    
    [Service]
    Type=forking
    ExecStart=/usr/bin/lxc-start -n %i
    ExecStop=/usr/bin/lxc-stop -n %i
    StandardOutput=journal
    User=lxc
    Group=lxc
    Delegate=yes
    
    [Install]
    WantedBy=multi-user.target
    

    由于我命名了文件[email protected]并将其放置到/etc/systemd/system/我可以使用控制我的所有容器systemctl COMMAND [email protected]

    (请注意,lxc.service是原创者,负责lxc-autostart)

    欢迎对单元文件等进行任何改进!- 因为我不是专家,我基本上使用了官方文档和这个很好的答案。

    调优 - Systemd 用户服务

    向前迈出的另一步是使用 Systemd 用户服务,因此在部署新容器时无需充当 root。

    单元文件会略有不同:

    [Unit]
    Description=LXC container %I
    After=network.target
    
    [Service]
    Type=forking
    ExecStart=/usr/bin/lxc-start -n %i
    ExecStop=/usr/bin/lxc-stop -n %i
    StandardOutput=journal
    Delegate=yes
    
    [Install]
    WantedBy=default.target
    

    由于multi-user.target不可用于用户服务,我们必须default.target改为使用。

    这次必须启用用户延迟,以便服务在启动时而不是在用户登录时启动。可以使用以下命令从 root 帐户启用延迟:loginctl enable-linger <my-lxc-user>

    我将服务文件保存到.config/systemd/user/[email protected]并使用systemctl --user enable [email protected]

    • 2
  2. pit
    2022-03-11T11:40:45+08:002022-03-11T11:40:45+08:00

    我有 Debian 11.2 运行lxc(版本 4.0.11-1)的测试包。使用mprudek 的 systemd 单元( nano /etc/systemd/system/[email protected]) 时,无论是否启用延迟会话,我总是会收到此错误:

    $ journalctl -f -u lxc@container1
    Mär 10 20:32:42 vm-debian systemd[1]: [email protected]: Control process exited, code=exited, status=1/FAILURE
    Mär 10 20:32:42 vm-debian lxc-unpriv-start[485]: Can't start an unprivileged container on a pure CGroups v2 host without a systemd user session running.
    Mär 10 20:32:42 vm-debian lxc-unpriv-start[485]: If you are trying to get a non-interactive user to have unprivileged containers running, you need to
    Mär 10 20:32:42 vm-debian lxc-unpriv-start[485]: enable lingering sessions for that user, via loginctl enable-linger lxcuser as root.
    Mär 10 20:32:42 vm-debian systemd[1]: [email protected]: Failed with result 'exit-code'.
    Mär 10 20:32:42 vm-debian systemd[1]: Failed to start LXC container container1.
    

    我已经按如下方式更新了 systemd 单元,它就像一个魅力。我的非特权 LXC 容器在该lxcuser帐户下运行。

    [Unit]
    Description=LXC container %I
    Requires=systemd-user-sessions.service
    After=systemd-user-sessions.service
    Wants=systemd-user-sessions.service
    
    [Service]
    Type=forking
    ExecStart=/usr/bin/lxc-unpriv-start -n %i
    ExecStop=/usr/bin/lxc-stop -n %i
    StandardOutput=journal
    User=lxcuser
    Group=lxcuser
    Delegate=yes
    RemainAfterExit=1
    Restart=on-failure
    RestartSec=5
    SuccessExitStatus=0
    RestartForceExitStatus=1
    
    [Install]
    WantedBy=multi-user.target
    
    $ loginctl enable-linger lxcuser
    $ systemctl disable lxc@container1
    $ systemctl stop lxc@container1
    $ systemctl daemon-reload
    $ systemctl enable lxc@container1
    $ systemctl start lxc@container1
    
    • 1

相关问题

  • GRUB 配置以识别同一 Linux 发行版的不同桌面环境(安装)

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • 如何在拼音输入法中输入ü?

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