【问题标题】:Docker Tomcat exited 0 after runDocker Tomcat 运行后退出 0
【发布时间】:2016-10-20 14:58:52
【问题描述】:

我从Dockerfile 制作了一张图片:

FROM tomcat:8.0
COPY target/javahello.war /usr/local/tomcat/webapps/
EXPOSE 8080
CMD /usr/local/tomcat/bin/startup.sh

但在开始之后 - 它处于“退出”状态:

$ sudo docker run -ti 957a86defe4f
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/lib/jvm/java-7-openjdk-amd64/jre
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.

还有:

$ sudo docker ps -a | head
CONTAINER ID        IMAGE                                                                     COMMAND                CREATED             STATUS                        PORTS                     NAMES
dc2309620baf        957a86defe4f:latest                                                       "/bin/sh -c /usr/loc   25 seconds ago      Exited (0) 24 seconds ago                               insane_elion     

logs 什么都不显示:

$ sudo docker logs dc2309620baf
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/lib/jvm/java-7-openjdk-amd64/jre
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.

如果我直接从容器运行 startup.sh - Tomcat 会按预期工作:

$ sudo docker run -ti 957a86defe4f bash
root@b00b541e6ccb:/usr/local/tomcat# ./bin/startup.sh 
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/lib/jvm/java-7-openjdk-amd64/jre
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
# ps -axu | grep tomcat
root        15 44.7  1.1 6258648 193484 ?      Sl   14:54   0:04 /usr/lib/jvm/java-7-openjdk-amd64/jre/bin/java -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Djava.endorsed.dirs=/usr/local/tomcat/endorsed -classpath /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/usr/local/tomcat -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/usr/local/tomcat/temp org.apache.catalina.startup.Bootstrap start

我的CMD 有问题吗?

【问题讨论】:

    标签: tomcat docker


    【解决方案1】:

    带有startup.sh 的tomcat 将在后台启动tomcat(作为服务),docker 将以code 0 退出,这是正常和预期的行为。

    在这种情况下,您需要使用catalina.sh run 作为前台进程启动tomcat。

     FROM tomcat:8.0
     COPY target/javahello.war /usr/local/tomcat/webapps/
     EXPOSE 8080
     CMD /usr/local/tomcat/bin/catalina.sh run
    

    当您在容器内运行 startup.sh 时,它正在工作,因为您处于“bash”(您的前台进程)中。

    【讨论】:

      猜你喜欢
      • 2018-12-13
      • 2019-09-26
      • 2018-01-24
      • 2021-10-17
      • 1970-01-01
      • 2019-12-27
      • 2020-08-24
      • 2020-01-02
      • 2018-08-14
      相关资源
      最近更新 更多