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 / 问题 / 513036
Accepted
Jake
Jake
Asked: 2019-04-18 07:43:57 +0800 CST2019-04-18 07:43:57 +0800 CST 2019-04-18 07:43:57 +0800 CST

LXC 如何设置它的根挂载点?

  • 772

我正在尝试在 Ubuntu 中使用挂载命名空间。到目前为止,我可以使用以下命令创建一个空的挂载命名空间:

# mkdir test
# unshare --mount
# mount none test -t tmpfs
# cd test
# pivot_root . . 
# cd / <--- test becomes /

当我检查LXCUbuntu 容器时,该mount命令显示以下内容:

在此处输入图像描述

由于挂载命名空间最初获取了挂载点的副本,因此我假设/dev/sda1容器内部是全局的/dev/sda1(因为/dev/sda1一旦启动,容器内部就没有了),但/容器内部的内容对应于它的 rootfs。熟悉 LXC 的人能否解释一下 LXCpivot_root在容器内执行之前会执行哪些挂载操作?

mount lxc
  • 1 1 个回答
  • 1238 Views

1 个回答

  • Voted
  1. Best Answer
    Danila Kiver
    2019-04-20T07:25:37+08:002019-04-20T07:25:37+08:00

    要查看 LXC 实际做了什么,让我们创建一个新容器并通过以下方式跟踪其启动过程strace(1):

    [root@localhost /]# lxc-create -n testcontainer -t debian
    [root@localhost /]# strace -e trace=clone,chdir,mount,pivot_root,execve \
                               -f -o lxclog \
                               lxc-start -n testcontainer
    

    生成的跟踪被写入lxclog文件,这里是它最相关的部分(省略号由我添加,省略了一些不重要的调用):

    14671 clone(child_stack=0x7fff9379eb80, flags=CLONE_NEWNS|CLONE_NEWUTS|CLONE_NEWIPC|CLONE_NEWPID|CLONE_NEWNET|SIGCHLD) = 14677
    <...>
    14677 mount("/var/lib/lxc/testcontainer/rootfs", "/usr/lib64/lxc/rootfs", 0x7fe4c2d10eac, MS_BIND|MS_REC, NULL) = 0
    <...>
    14677 chdir("/usr/lib64/lxc/rootfs")    = 0
    14677 pivot_root(".", "/usr/lib64/lxc/rootfs/lxc_putold") = 0
    14677 chdir("/")
    <...>
    14677 execve("/sbin/init", ["/sbin/init"], [/* 1 var */]) = 0
    

    首先,一个新进程(PID 14677)由lxc-start(PID 14671)使用产生clone(2)并被放置在新的挂载命名空间(CLONE_NEWNS标志)中。然后在这个新的挂载命名空间中,容器的根文件系统(/var/lib/lxc/testcontainer/rootfs)绑定(MS_BIND标志)到/usr/lib64/lxc/rootfs,然后成为新的根。最后,当容器初始化完成后,进程 14677 成为容器的init.

    这里重要的是容器的挂载命名空间的根目录是属于主机根 FS的目录的绑定挂载。这就是为什么容器的根挂载仍然有/dev/sda1作为mount(8)输出中的源。但是,还有一个没有显示的差异mount(8)- 要查看它,请尝试findmnt(8)在容器内:

    root@testcontainer:~# findmnt
    TARGET                                SOURCE                     FSTYPE    OPTIONS
    /                                     /dev/sda1[/var/lib/lxc/testcontainer/rootfs]
    

    findmnt(8)将此与主机系统的输出进行比较:

    [root@localhost /]# findmnt
    TARGET                                SOURCE                    FSTYPE     OPTIONS
    /                                     /dev/sda1
    

    请注意,源是相同的,但在容器内您还可以看到绑定挂载的源目录。

    • 1

相关问题

  • 阻止挂载系统调用

  • 将局域网硬盘挂载到 linux fedora

  • 使用 LXC 2.x 将主机文件夹挂载到来宾,但它是只读的吗?

  • 无法在 Alpine Linux LXC 上启动 NFS 服务器

  • LXC 容器内部从零开始的 Linux

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