2

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

虽然这确实解决了我的问题,但我注意到在重新启动主机后,我第一次尝试在容器中设置循环设备会失败(failed to set up loop device: No such file or directory),但在退出并重新启动容器后它会成功(/dev/loop0)。如果由于某种原因我需要在容器中设置第二个循环设备(/dev/loop1)(在第一个工作之后),它也会失败,直到我退出并重新启动容器。

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

我怀疑我遗漏了一些明显的关于 losttup 在主机上所做的事情,它显然无法完全在容器内完成,或者更具体地说,这可能是 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
4

2 回答 2

3

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

在我的 vm 启动后,它没有配置任何循环设备,这没关系,因为 mount 可以在需要时创建其他设备,但是:

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

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

所以我尝试过的(而且似乎有效)我将 /dev 作为卷挂载传递给 docker

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

如果你还有这些东西,我想知道你是否也可以试试看它是否有帮助。

于 2021-04-22T00:32:06.630 回答
0

除了您已经找到的方法之外,我能想到的唯一其他方法是/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 index in 0 1 2 3 4 5
do
  mknod /dev/loop$i $major $i
done

把它放在 /etc/rc.local,你的系统的等价物或者安排它在启动时运行。

于 2021-02-03T02:18:13.643 回答