准备
- 打包好的 SpringBoot 项目。
- Linux 服务器(本示例使用的是 CentOS 7)。
- 安装好的 Docker 运行环境。
在 Linux 上安装 Docker 可参考我的另一篇文章:Linux 安装 Docker_爱辰-CSDN博客
上传 jar 包到服务器
-
新建目录
mkdir docker cd docker
-
将jar包上传到新建的目录下
[root@localhost docker]# ls docker-image-test-0.0.1-SNAPSHOT.jar
新建Dockerfile文件
vim Dockerfile
文件内容如下
# Docker image for springboot file run
# VERSION 0.0.1
# Author: aichen
# 基础镜像使用java
FROM openjdk:11.0.4
# 作者
MAINTAINER aichen
# VOLUME 指定了临时文件目录为/tmp。
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
VOLUME /tmp
# 将jar包添加到容器中并更名为app.jar
ADD docker-image-test-0.0.1-SNAPSHOT.jar app.jar
# 运行jar包
RUN bash -c 'touch /app.jar'
# -Djava.security.egd=file:/dev/./urandom 选项可以在一定程度上加快应用启动速度
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
打包Docker镜像文件
docker build -t hellodocker ./
参数说明:
-t : 镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像设置多个标签。
打包过程中docker会自动拉取所需的依赖镜像。
./ : 打包时要使用的上下文路径。
Successfully built 8165c3845d2f
Successfully tagged hellodocker:latest
出现这两行说明已经打包成功了。
查看本地镜像:
[root@localhost docker]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hellodocker latest 8165c3845d2f 3 minutes ago 640MB
openjdk 11.0.4 e6ca4006334d 2 years ago 605MB
启动容器
docker run -d -p 8080:8080 -v /log:/log hellodocker
参数说明:
-d : 后台运行容器,并返回容器ID;
-p : 指定端口映射,格式为:主机(宿主)端口:容器端口
-v : 文件路径映射,宿主机目录:容器目录
查看项目的启动日志:
[root@localhost docker]# cat /log/hello.log
2021-11-03 03:14:13.253 INFO 1 --- [main] c.a.d.DockerImageTestApplication : Starting DockerImageTestApplication v0.0.1-SNAPSHOT using Java 11.0.4 on 4d2edf30f5a3 with PID 1 (/app.jar started by root in /)
2021-11-03 03:14:13.255 INFO 1 --- [main] c.a.d.DockerImageTestApplication : No active profile set, falling back to default profiles: default
2021-11-03 03:14:15.140 INFO 1 --- [main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat initialized with port(s): 8080 (http)
2021-11-03 03:14:15.165 INFO 1 --- [main] o.apache.catalina.core.StandardService : Starting service [Tomcat]
2021-11-03 03:14:15.165 INFO 1 --- [main] org.apache.catalina.core.StandardEngine : Starting Servlet engine: [Apache Tomcat/9.0.54]
2021-11-03 03:14:15.307 INFO 1 --- [main] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext
2021-11-03 03:14:15.307 INFO 1 --- [main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 1969 ms
2021-11-03 03:14:16.612 INFO 1 --- [main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8080 (http) with context path ''
2021-11-03 03:14:16.648 INFO 1 --- [main] c.a.d.DockerImageTestApplication : Started DockerImageTestApplication in 4.478 seconds (JVM running for 5.274)
2021-11-03 03:15:03.090 INFO 1 --- [http-nio-8080-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring DispatcherServlet 'dispatcherServlet'
2021-11-03 03:15:03.091 INFO 1 --- [http-nio-8080-exec-1] o.s.web.servlet.DispatcherServlet : Initializing Servlet 'dispatcherServlet'
2021-11-03 03:15:03.092 INFO 1 --- [http-nio-8080-exec-1] o.s.web.servlet.DispatcherServlet : Completed initialization in 1 ms
2021-11-03 03:15:03.170 INFO 1 --- [http-nio-8080-exec-1] c.a.d.controller.HelloController : Hello Docker Image!
访问项目接口:
[root@localhost docker]# curl http://127.0.0.1:8080/hello
Hello Docker Image!