docker 运行tomcat 并部署 java web项目

以下tomcat官方镜像中tomcat:7 和tomcat:8的目录。

CATALINA_BASE:   /usr/local/tomcat
CATALINA_HOME:   /usr/local/tomcat
CATALINA_TMPDIR: /usr/local/tomcat/temp
JRE_HOME:        /usr
CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar

先将简单的war包上传到服务器放在任意目录,我的war包是docker.war,   这里是放在docker_tomcat/webapps, cd 进去docker_tomcat,  执行如下命令

docker run -it --rm -p 8888:8080 -v $PWD/webapps:/usr/local/tomcat/webapps tomcat:8.0

参数解析:

-it         #  是-i  和 -t的简写, 表示以交互式的方式运行容器,加上-d表示后台运行
--rm        #当容器被停止时自动删除容器
-p 8888:80  #80是为容器中的tomcat设置的端口, 这里表示将80映射到宿主机8888端口, 如果只写-p 80  容器会随机取值32768~61000中较大的端口号来映射到80端口上
-v          # 将tomcat中的usr/local/tomcat/webapps目录映射到宿主机当前目录的webapps目录
tomcat:8.0  # 镜像名:tag标签

运行之后会输出taomcat的启动日志如下:

 1 # docker run -it --rm -p 8888:8080 -v $PWD/webapps:/usr/local/tomcat/webapps tomcat:8.0
 2 Using CATALINA_BASE:   /usr/local/tomcat
 3 Using CATALINA_HOME:   /usr/local/tomcat
 4 Using CATALINA_TMPDIR: /usr/local/tomcat/temp
 5 Using JRE_HOME:        /docker-java-home/jre
 6 Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
 7 22-Oct-2018 05:09:13.274 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server version:        Apache Tomcat/8.0.53
 8 22-Oct-2018 05:09:13.276 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server built:          Jun 29 2018 14:42:45 UTC
 9 22-Oct-2018 05:09:13.277 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server number:         8.0.53.0
10 22-Oct-2018 05:09:13.277 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
11 22-Oct-2018 05:09:13.278 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Version:            4.10.5-1.el6.elrepo.x86_64
12 22-Oct-2018 05:09:13.278 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
13 22-Oct-2018 05:09:13.279 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Java Home:             /usr/lib/jvm/java-7-openjdk-amd64/jre
14 22-Oct-2018 05:09:13.279 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Version:           1.7.0_181-b01
15 22-Oct-2018 05:09:13.280 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Vendor:            Oracle Corporation
16 22-Oct-2018 05:09:13.280 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_BASE:         /usr/local/tomcat
17 22-Oct-2018 05:09:13.280 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_HOME:         /usr/local/tomcat
18 22-Oct-2018 05:09:13.281 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties
19 22-Oct-2018 05:09:13.282 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
20 22-Oct-2018 05:09:13.285 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djdk.tls.ephemeralDHKeySize=2048
21 22-Oct-2018 05:09:13.286 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.protocol.handler.pkgs=org.apache.catalina.webresources
22 22-Oct-2018 05:09:13.286 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dignore.endorsed.dirs=
23 22-Oct-2018 05:09:13.287 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/usr/local/tomcat
24 22-Oct-2018 05:09:13.287 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.home=/usr/local/tomcat
25 22-Oct-2018 05:09:13.288 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.io.tmpdir=/usr/local/tomcat/temp
26 22-Oct-2018 05:09:13.288 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent Loaded APR based Apache Tomcat Native library 1.2.17 using APR version 1.5.1.
27 22-Oct-2018 05:09:13.288 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true].
28 22-Oct-2018 05:09:13.297 INFO [main] org.apache.catalina.core.AprLifecycleListener.initializeSSL OpenSSL successfully initialized (OpenSSL 1.1.0f  25 May 2017)
29 22-Oct-2018 05:09:13.464 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-apr-8080"]
30 22-Oct-2018 05:09:13.495 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["ajp-apr-8009"]
31 22-Oct-2018 05:09:13.501 INFO [main] org.apache.catalina.startup.Catalina.load Initialization processed in 1214 ms
32 22-Oct-2018 05:09:13.591 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service Catalina
33 22-Oct-2018 05:09:13.595 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet Engine: Apache Tomcat/8.0.53
34 22-Oct-2018 05:09:13.666 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive /usr/local/tomcat/webapps/docker.war
35 22-Oct-2018 05:09:14.347 WARNING [localhost-startStop-1] org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]. Default version will be used.
36 22-Oct-2018 05:09:14.742 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web application archive /usr/local/tomcat/webapps/docker.war has finished in 1,075 ms

从34行开始就可以看到已经在部署docker.war了

浏览器访问: http://<ip>:<port>/<application-name> 也就是

因为是用来练习docker中部署war, 所以我的docker.war  很简单,  就是用idea 新建出来的project 什么后台代码都没加, 只是改了index.jsp的内容。 

我的web程序结构:

 done.

猜你喜欢

转载自www.cnblogs.com/jxlsblog/p/9829723.html