• 执行 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.

image-1684919040776

首先观察一下我的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 此方法只适用于非挂载宿主机目录,挂载宿主机目录时需要注意目录权限问题

RUNCMD的执行时机不同,RUN是在构建镜像时执行,属于root权限。CMD是在运行镜像时执行,此时会受到运行用户权限管控