始终作为容器入口点运行的bash脚本。我刚刚从Al菠萝3.13升级到Al菠萝3.15.0,脚本开始失败,无法对挂载和卸载文件进行"-r“检查。
码头版18.06.1-ce, build e68fc7a
libseccomp版本libseccomp2/now 2.4.1-0ubuntu0.18.04.2
最小算例
bash-5.1# ls -lt try
-rw-r--r-- 1 root root 0 Mar 24 08:47 try
bash-5.1# cat test.sh
#!/bin/bash
if [ ! -r /tmp/try ] ; then
echo "fail -r"
fi
if [ ! -f /tmp/try ] ; then
echo "fail -f"
fi
bash-5.1# bash test.sh
fail -r
bash-5.1# sh test.sh
bash-5.1#发布于 2022-03-27 08:29:26
这个问题已经在这里被记录下来:https://github.com/alpinelinux/docker-alpine/issues/156
建议的解决方案在这里列出:3.14.0#faccessat2
由于我无法更新docker和libseccomp版本,所以我尝试了第三个选项,并且工作正常。
defaultAction更改为SCMP_ACT_TRACE,然后--seccomp-profile=default.json可以传递给dockerd,或者--security-opt=seccomp=default.json传递给docker create或docker run。这将导致系统调用返回ENOSYS而不是EPERM,从而使容器返回faccessat。https://stackoverflow.com/questions/71600607
复制相似问题