当前位置:   article > 正文

Docker 部署启动 Spring boot 项目_springboot docker

springboot docker

目录

本地准备 Spring boot 项目源码

打包 Spring Boot 项目到 Docker

查看 docker 容器日志

查看 log4j2 文件日志


Docker 概述 与 CentOS 上安装、卸载、启动:没有安装 docker 的,需要先安装 docker

CentOS 7.x 安装 Maven:因为后期需要在 linux 上使用 maven 打包项目,所以必须先安装 maven

Docker 安装 Java Jdk 8:因为 docker 中运行 java 项目,必须先有 java 运行环境。

本地准备 Spring boot 项目源码

1、创建 Spring boot 项目,为了方便测试,导入 spring-boot-starter-web 模块,做 http 请求。

2、pom.xml 文件中引入 docker 依赖:

  1. <properties>
  2. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  3. <java.version>1.8</java.version>
  4. <!--自定义 docker 镜像前缀,类似 docker.io/mysql 中的 docker.io-->
  5. <docker.image.prefix>wangmaoxiong.com</docker.image.prefix>
  6. </properties>
  7. ...
  8. <build>
  9. <plugins>
  10. <plugin>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-maven-plugin</artifactId>
  13. </plugin>
  14. <!-- docker 插件,用于 maven 打包时生成 docker 镜像 -->
  15. <plugin>
  16. <groupId>com.spotify</groupId>
  17. <artifactId>docker-maven-plugin</artifactId>
  18. <version>1.0.0</version>
  19. <configuration>
  20. <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
  21. <!-- dockerfile 配置文件所在的目录-->
  22. <dockerDirectory>src/main/docker</dockerDirectory>
  23. <imageTags>${project.version}</imageTags>
  24. <resources>
  25. <resource>
  26. <targetPath>/</targetPath>
  27. <directory>${project.build.directory}</directory>
  28. <include>${project.build.finalName}.jar</include>
  29. </resource>
  30. </resources>
  31. </configuration>
  32. </plugin>
  33. </plugins>
  34. </build>

3、在 src/mian 目录下新建 docker 子目录,然后在 docker 目录下创建 dockerfile 文件(不需要后缀名),这个路径需要与 pom.xml 文件中指定的路径一致,内容如下:

  1. FROM docker.io/java:8
  2. VOLUME /tmp/tomcat
  3. ADD java-se-1.0-SNAPSHOT.jar java-se-1.0.jar
  4. ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/java-se-1.0.jar"]

FROM:指定 docker 中已经下载好的 java jdk 镜像,docker.io/java:8 是已经下载好的 jdk 8 镜像,根据实际情况指定。
VOLUME:自定义一个临时目录,用于存储 tomcat 工作日志。
ADD:复制文件并且重命名文件(根据自己实际情况指定)。
   java-se-1.0-SNAPSHOT.jar 是 package 或者 install 命令打好的包名称,本地就能看到,在 linux 服务器上也会使用  maven 命令对源码进行打包。
   java-se-1.0.jar:表示将 linux 上 maven 打好的包复制到 docker 容器中,同时重命名。
ENTRYPOINT:初始化配置或者自定义配置。

4、为了更贴合实际情况,引用 sfl4j + log4j2 日志框架记录日志(其他日志框架也是同理),需要注意的是日志文件存储的位置推荐指定为绝对路径,比如类路径下  log4j2.xml 中指定日志存储路径如下:

  1. <!--文件存储文件设置-->
  2. <!--fileName:文件存储路径及名称,可以是绝对路径或者相对路径; 存储的永远是最新的日志信息-->
  3. <!--filePattern:当 fileName 指定的文件大小超过限制,就会根据此文件名规则新建存档目录与文件-->
  4. <RollingFile name="RollingFileInfo" fileName="/home/wangmx/logs/java-se/java-se.log"
  5. filePattern="/home/wangmx/logs/java-se/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
  6. <!--日志文件中日志信息的格式-->
  7. <PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - [%t] - %l - %m%n"/>
  8. <Policies>
  9. <TimeBasedTriggeringPolicy/>
  10. <!--日志文件大小超过多少时进行存档-->
  11. <SizeBasedTriggeringPolicy size="500 MB"/>
  12. </Policies>
  13. </RollingFile>

5、提供一个控制层访问接口,同时使用 slf4j 记录一些日志,随便写点东西,能访问测试就行。

6、application.yml 配置文件指定 server.port=8317

打包 Spring Boot 项目到 Docker

1、将本地需要发版的项目源码整个上传到远程服务器中,需要在 Linux 上借助 maven 将它打包到 docker 中。

2、上传后切换到项目的根目录,然后打包:mvn clean package -Dmaven.test.skip=true docker:build

       clean package:表示先清理缓存,然后打包
       -Dmaven.test.skip=true:表示跳过测试文件
       docker:build:表示将打好的包构建到 docker 容器中作为镜像 

3、打包看到 BUILD SUCCESS 表示成功,此时即可看到构建好的镜像:docker images

4、拥有了镜像了,则与使用普通的镜像无异了,可以开始运行它:docker run --name java-se-1.0 -p 8317:8317 -d 7d1bc7859b6d

      --name:表示自定义容器名称
      -p:表示端口映射,第一个是 Linux 外部端口,第二个是 Dcoker 内部端口
      -d:表示程序后台运行
      7d1bc7859b6d:镜像id(image id),根据实际情况指定

5、最后一步,Linux 防火墙开启对外的端口:

        firewall-cmd --zone=public --list-port       #查看防火墙开放的端口
        firewall-cmd --zone=public --add-port=8317/tcp --permanent    #防火墙开放 8317 端口
        firewall-cmd --reload                               #重启防火墙,端口配置才能生效

6、最后即可远程访问 docker 中启动好的 Spring boot 服务了。

查看 docker 容器日志

1、线上的项目查看日志信息是绝对有的,方式1是直接查看容器日。

2、查看容器日志:docker logs container-name/container-id,比如:docker logs -f --tail=100 java-se-1.0  ,实时查看最新的 100 条日志信息.

docker logs -f -t --since="2021-06-13" --tail=100 java-se-1.0        -- 查看 2021-06-13 日期后的 100 条日志,实时跟踪日志,显示时间戳
docker logs -f -t --since="2021-06-13T16:20:00" --tail=100 java-se-1.0   -- 查看 2021-06-13 16:20:00 时刻后的 100 条日志,实时跟踪日志,显示时间戳
docker logs -f -t --since="2021-06-13" java-se-1.0      -- 查看 2021-06-13 日期后的日志,实时跟踪日志,显示时间戳
docker logs --since 30m java-se-1.0  -- 查看最近 30 分钟内的日志

查看 log4j2 文件日志

1、应用中使用的日志框架 log4j2、logback 等等输出的日志文件如何查看呢?因为服务是在 docker 容器中运行的,所以日志信息也是存储在 docker 容器中。

2、先要进入 docker 容器:docker exec -it java-se-1.0 /bin/bash ,java-se-1.0 是容器名称,根据实际情况指定。

3、然后进入日志存储目录下即可看到,比如:fileName="/home/wangmx/logs/java-se/java-se.log",则,cd /home/wangmx/logs/java-se.

4、实时查看日志信息,显示最后 100 条信息:tail -f -n 100 java-se.log

5、也可以使用 vim 编辑器查看(Docker 安装 Vim 编辑器)。

6、有时候使用 vim 还是不能满足需求,比如我们需要把日志文件导出来研究一下:Docker 容器与宿主服务器文件复制

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/681667
推荐阅读
相关标签
  

闽ICP备14008679号