我有这个容器基于debian:jessie(但是与我有相同的问题,这并不是很相关alpine:3.3)。我到达需要的地方
debian:jessie
alpine:3.3
mount --bind /htdocs/www /home/user/example.com/www
我得到
mount: permission denied
我在任何内核日志中都找不到任何东西,而且-vvv没有任何有趣的结果。我显然可以在主机上执行此操作(使用任何其他对子树/节点)。在我上面的示例中,/ htdocs / www是Docker卷的安装点,但它似乎没有任何意义,因为mount --bind容器内没有任何一对子树/节点。
-vvv
mount --bind
要使用mount系统调用,您需要具备此CAP_SYS_ADMIN功能。默认情况下,Docker在生成容器时会放弃所有功能(这意味着即使以 root 身份,您也不能做任何事情)。有关更多信息,请参见mount(2)手册页。
mount
CAP_SYS_ADMIN
您可以使用--cap-add=SYS_ADMIN标志启动容器,以将此功能添加到容器中:
--cap-add=SYS_ADMIN
root@host > docker run --rm -it --cap-add=SYS_ADMIN debian:jessie root@ee0b1d5fe546:/# mkdir /mnt/test root@ee0b1d5fe546:/# mount --bind /home /mnt/test/ root@ee0b1d5fe546:/#
请谨慎使用 。不要在特权容器中运行不受信任的软件。