- 执行 Docker 命令 提示 permission denied
- docker命令permission denied
- docker容器启动报错Permission denied
- Docker容器内Permission denied解决方法
- docker: Error response from daemon: OCI runtime create failed: container_linux.go:349: starting container process caused “exec: “/usr/local/tomcat/bin/catalina.sh”: permission denied”: unknown.
首先观察一下我的Dockerfile
FROM adoptopenjdk/openjdk8:ubi
# 工作目录
WORKDIR /usr/local
# 加入tomcat
COPY apache-tomcat-9.0.75 /usr/local/tomcat
ENV TZ=Asia/Shanghai
EXPOSE 8080
CMD chmod 777 /usr/local/tomcat/bin/*.sh
#启动时运行tomcat
CMD ["/usr/local/tomcat/bin/catalina.sh","run"]
这是由于启动docker时使用的用户不是root导致 CMD chmod
无效,将CMD chmod 777
改为 RUN chmod 777
即可
解决
将添加全选的 CMD chmod 777 /usr/local/tomcat/bin/*.sh
改为
RUN chmod 777 /usr/local/tomcat/bin/*.sh
PS 此方法只适用于非挂载宿主机目录,挂载宿主机目录时需要注意目录权限问题
RUN
与CMD
的执行时机不同,RUN
是在构建镜像时执行,属于root权限。CMD
是在运行镜像时执行,此时会受到运行用户权限管控