主机重新启动后,容器中的循环设备设置(losetup、挂载等)立即失败

问题描述 投票:0回答:2

我正在尝试在 Centos 8 上的容器环境 (podman) 中填充磁盘映像。我最初遇到了从容器访问循环设备的问题,直到找到我需要以 root 身份运行 podman 的 SO 和其他源并使用

--privileged
选项。

虽然这确实解决了我的问题,但我注意到在重新启动主机后,我第一次尝试在容器中设置循环设备会失败(

failed to set up loop device: No such file or directory
),但是在退出并重新启动容器后它会成功(/dev /循环0)。 如果由于某种原因我需要在容器中设置第二个循环设备(/dev/loop1)(在第一个循环设备工作之后),它也会失败,直到我退出并重新启动容器。

进一步实验,我发现如果我运行

losetup --find --show <file created with dd>
足够多的时间来附加我需要的最大数量的循环设备,然后使用
losetup -D
分离所有这些,我可以避免循环设备容器中完全出现错误。

我怀疑我遗漏了一些关于losetup在主机上所做的事情的明显内容,它显然无法完全在容器内完成,或者更具体地说,这可能是一个Centos+podman+losetup问题。 关于正在发生的事情以及为什么我必须在重新启动后预先连接/分离循环设备以避免容器内出现问题有什么见解吗?

在 Centos 8 系统上重现的步骤(重新启动后连接/分离一次):

$ dd if=/dev/zero of=file bs=1024k count=10
10+0 records in
10+0 records out
10485760 bytes (10 MB, 10 MiB) copied, 0.00826706 s, 1.3 GB/s
$ cp file 1.img
$ cp file 2.img
$ cp file 3.img
$ cp file 4.img
$ sudo podman run -it --privileged --rm -v .:/images centos:8 bash

[root@2da5317bde3e /]# cd images
[root@2da5317bde3e images]# ls
1.img  2.img  3.img  4.img  file
[root@2da5317bde3e images]# losetup --find --show 1.img
/dev/loop0
[root@2da5317bde3e images]# losetup --find --show 2.img
losetup: 2.img: failed to set up loop device: No such file or directory
[root@2da5317bde3e images]# losetup -D
[root@2da5317bde3e images]# exit

exit
$ sudo podman run -it --privileged --rm -v .:/images centos:8 bash

[root@f9e41a21aea4 /]# cd images
[root@f9e41a21aea4 images]# losetup --find --show 1.img
/dev/loop0
[root@f9e41a21aea4 images]# losetup --find --show 2.img
/dev/loop1
[root@f9e41a21aea4 images]# losetup --find --show 3.img
losetup: 3.img: failed to set up loop device: No such file or directory
[root@f9e41a21aea4 /]# losetup -D
[root@f9e41a21aea4 images]# exit

exit
$ sudo podman run -it --privileged --rm -v .:/images centos:8 bash

[root@c93cb71b838a /]# cd images
[root@c93cb71b838a images]# losetup --find --show 1.img
/dev/loop0
[root@c93cb71b838a images]# losetup --find --show 2.img
/dev/loop1
[root@c93cb71b838a images]# losetup --find --show 3.img
/dev/loop2
[root@c93cb71b838a images]# losetup --find --show 4.img
losetup: 4.img: failed to set up loop device: No such file or directory
centos filesystems containers mount podman
2个回答
7
投票

我知道它有点旧,但我偶然发现了类似的问题,这里是我发现的:

我的虚拟机启动后,它没有配置任何循环设备,这没关系,因为挂载可以根据需要创建其他设备,但是:

docker 似乎将覆盖层覆盖在 /dev 上,因此在容器启动后它不会看到 /dev/ 中所做的任何更改,因此即使 mount 请求创建新的循环设备并且它们实际上是创建的,我正在运行的容器也不会”看不到它并且由于没有可用的循环设备而无法安装。

一旦重新启动容器,它将从 /dev 获取新的更改并查看循环设备并成功挂载,直到用完它们并再次尝试请求。

所以我尝试过(并且似乎有效),我将 /dev 作为卷安装传递给 docker,如下所示

docker -v /dev:/dev -it --rm <image> <command> and it did work.

如果你还有这个东西,我想知道你是否也可以尝试一下,看看是否有帮助。


3
投票

除了您已经找到的方法之外,我能想到的唯一其他方法是在启动时自己创建

/dev/loop
设备。像这样的东西应该有效:

modprobe loop  # This may not be necessary, depending on your kernel build but is harmless.
major=$(grep loop /proc/devices | cut -c3)
for i in {0..5}
do
  mknod /dev/loop$i b $major $i
done

将其放入 /etc/rc.local(您的系统的等效项)中,或者以其他方式安排它在启动时运行。

© www.soinside.com 2019 - 2024. All rights reserved.