准备
- 需要发布的 war 包。
- Linux 服务器(本示例使用的是 CentOS 7)。
- 安装好的 Docker 运行环境。
在 Linux 上安装 Docker 可参考我的另一篇文章:Linux 安装 Docker_爱辰-CSDN博客
上传 war 包到服务器
-
新建目录
mkdir docker cd docker
-
将 war 包上传到新建的目录下
[root@localhost docker]# ls docker.war
新建Dockerfile文件
vim Dockerfile
文件内容如下
# docker制作基于tomcat的项目镜像
# VERSION 0.0.1
# Author: aichen
# 基础镜像使用tomcat8
FROM tomcat:8
# 作者
MAINTAINER aichen
# 将war包放入容器的tomcat中
COPY docker.war /usr/local/tomcat/webapps/docker.war
打包Docker镜像文件
docker build -t docker-tomcat ./
参数说明:
-t : 镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像设置多个标签。
打包过程中docker会自动拉取所需的依赖镜像。
./ : 打包时要使用的上下文路径。
Successfully built c64991e0de49
Successfully tagged docker-tomcat:latest
出现这两行说明已经打包成功了。
查看本地镜像:
[root@localhost docker]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
docker-tomcat latest c64991e0de49 33 seconds ago 697MB
tomcat 8 8565c9940b24 2 days ago 678MB
启动容器
docker run --name docker -d -p 8080:8080 -v /log:/log docker-tomcat
参数说明:
–name : 容器名称
-d : 后台运行容器,并返回容器ID;
-p : 指定端口映射,格式为:主机(宿主)端口:容器端口
-v : 文件路径映射,宿主机目录:容器目录
访问项目接口:
[root@localhost docker]# curl http://127.0.0.1:8080/hello
Hello Docker Image!
查看项目的日志:
[root@localhost docker]# cat /log/hello.log
2021-12-06 13:23:20.422 INFO 1 --- [localhost-startStop-1] c.a.d.DockerImageTestApplication : Starting DockerImageTestApplication v0.0.1-SNAPSHOT using Java 11.0.13 on eeac266f8b5b with PID 1 (/usr/local/tomcat/webapps/docker/WEB-INF/classes started by root in /usr/local/tomcat)
2021-12-06 13:23:20.424 INFO 1 --- [localhost-startStop-1] c.a.d.DockerImageTestApplication : No active profile set, falling back to default profiles: default
2021-12-06 13:23:21.758 INFO 1 --- [localhost-startStop-1] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 1308 ms
2021-12-06 13:23:23.269 INFO 1 --- [localhost-startStop-1] com.aichen.dockerimagetest.MyRunner : 容器启动完毕。。。。。。
2021-12-06 13:23:23.274 INFO 1 --- [localhost-startStop-1] c.a.d.DockerImageTestApplication : Started DockerImageTestApplication in 3.916 seconds (JVM running for 8.372)
2021-12-06 13:23:23.276 INFO 1 --- [localhost-startStop-1] com.aichen.dockerimagetest.MyRunner : 系统启动完毕。。。。。。
2021-12-06 13:24:09.864 INFO 1 --- [http-nio-8080-exec-3] o.s.web.servlet.DispatcherServlet : Initializing Servlet 'dispatcherServlet'
2021-12-06 13:24:09.866 INFO 1 --- [http-nio-8080-exec-3] o.s.web.servlet.DispatcherServlet : Completed initialization in 1 ms
2021-12-06 13:24:09.923 INFO 1 --- [http-nio-8080-exec-3] c.a.d.controller.HelloController : Hello Docker Image!