docker run 运行容器自动结束的解决

时间:2022-09-08 08:30:26

今天遇到了用Dockerfile创建镜像,镜像运行后容器自动结束问题.

启动命令:

docker run -d -p 8080:8080 -v /usr/local/tomcat7.0/logs:/usr/local/tomcat7.0/logs --name tomcatweb tomcat:7.0

运行以后用docker ps 发现docker 容器已经结束了

查找资料后发现 这个问题并不复杂 原因是应为:Docker容器后台运行,就必须有一个前台进程.

解决办法:

1.将运行进程发放入前台启动 如:nginx nginx -g "daemon off;" tomcat ./catalina.sh run

2.使用 tail , top 这种可以前台运行的程序,特别推荐 tail ,输出你的log文件.

在Dockerfile中加上ENTRYPOINT /opt/tomcat7.0/bin/startup.sh && tail -F /opt/tomcat7.0/logs/catalina.out

补充知识:docker pull 拉取的tomcat 没有生成日志,自己就手写了一个tocmat dockerfile文件,实测有日志生成

一、dockfile 文件以及解释如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
FROM openjdk:8-jre
MAINTAINER zyj
 
ENV JAVA_HOME /docker-java-home
ENV CATALINA_HOME /opt/tomcat
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/bin:$CATALINA_HOME/scripts
 
#时区
RUN echo "Asia/Shanghai" > /etc/timezone
RUN mv /etc/localtime /etc/localtime_bak
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
 
#TOMCAT
ENV TOMCAT_MAJOR 8
ENV TOMCAT_VERSION 8.5.35
 
RUN wget http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.41/bin/apache-tomcat-8.5.41.tar.gz && \
 tar -zxvf apache-tomcat-8.5.41.tar.gz && \
 rm apache-tomcat*.tar.gz && \
 mv apache-tomcat* ${CATALINA_HOME}
 
RUN chmod +x ${CATALINA_HOME}/bin/*sh
RUN chmod 777 ${CATALINA_HOME}/logs/
RUN chmod 777 ${CATALINA_HOME}/webapps/
 
#设置用户名密码 admin
ADD tomcat-users.xml /opt/tomcat/conf/
 
#远程访问
ADD context.xml /opt/tomcat/webapps/manager/META-INF/
 
ENV LANG zh_CN.UTF-8
 
#开放端口
EXPOSE 8080
 
# Launch Tomcat
WORKDIR /opt/tomcat/bin
CMD ["catalina.sh","run"]

注意:该docker 需要引用外部文件

详见 github

二、dockerfile 编译命令

docker build -f dockerfile -t zyj/tomcat .

三、运行命令

?
1
2
docker run -d -p 8080:8080 --name tomcat8
-v /opt/docker-tomcat/logs/:/opt/tomcat/logs/ -v /opt/docker-tomcat/webapps/:/opt/tomcat/webapps/ -v /opt/docker-tomcat/context.xml:/opt/tomcat/webapps/manager/META-INF/context.xml -v /opt/docker-tomcat/tomcat-users.xml:/opt/tomcat/conf/tomcat-users.xml --privileged=true zyj/tomcat

以上这篇docker run 运行容器自动结束的解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/u014242496/article/details/70792257