高山dockerimage上的catalina.sh无法启动

时间:2018-07-24 13:34:20

标签: docker dockerfile tomcat8 alpine

我有这个Dockerfile,它是带有tomcat和Java的高山映像。 问题是在以分离模式运行容器时,我无法运行catalina.sh脚本。我收到以下错误:

$ docker run -d --name login2 -p 8080:8080 alpine:login-o365
8fbd3fda6c2f171045f2338abf4887b5a2374e1f42537717649a3fb6b61c4cb2
C:\Program Files\Docker Toolbox\docker.exe: Error response from daemon: OCI runtime create failed: container_linux.go:348: starting container process caused "exec: \"/opt/tomcat/bin\": permission denied": unknown.

此错误之后,我手动访问了该容器,并检查/ opt / tomcat / bin中的catalina.sh是否已将权限设置如下:

-rwxr-x --- 1个根目录21579年6月9日catalina.sh

这是什么错误?这与较小的图像有关吗?这是我拥有的Dockerfile:

FROM davidcaste/alpine-java-unlimited-jce:jre8


ENV TOMCAT_MAJOR=8 \
TOMCAT_VERSION=8.5.3 \
TOMCAT_HOME=/opt/tomcat \
CATALINA_HOME=/opt/tomcat/bin \
CATALINA_OUT=/dev/null


RUN apk upgrade --update && \
apk add --update curl bash wget && \
curl -jksSL -o /tmp/apache-tomcat.tar.gz http://archive.apache.org/dist/tomcat/tomcat-${TOMCAT_MAJOR}/v${TOMCAT_VERSION}/bin/apache-tomcat-${TOMCAT_VERSION}.tar.gz && \
gunzip /tmp/apache-tomcat.tar.gz && \
tar -C /opt -xf /tmp/apache-tomcat.tar && \
ln -s /opt/apache-tomcat-${TOMCAT_VERSION} ${TOMCAT_HOME} && \
rm -rf ${TOMCAT_HOME}/webapps/* && \
apk del curl && \
rm -rf /tmp/* /var/cache/apk/*

COPY logging.properties ${TOMCAT_HOME}/conf/logging.properties
COPY server.xml ${TOMCAT_HOME}/conf/server.xml

VOLUME ["/logs"]
EXPOSE 8080

CMD ["/opt/tomcat/bin", "-n", "-c", "catalina.sh"]

1 个答案:

答案 0 :(得分:0)

也许使用此方法可能会有所帮助

CMD /opt/tomcat/bin/catalina.sh run