赞
踩
目录
Docker 概述 与 CentOS 上安装、卸载、启动:没有安装 docker 的,需要先安装 docker
CentOS 7.x 安装 Maven:因为后期需要在 linux 上使用 maven 打包项目,所以必须先安装 maven
Docker 安装 Java Jdk 8:因为 docker 中运行 java 项目,必须先有 java 运行环境。
1、创建 Spring boot 项目,为了方便测试,导入 spring-boot-starter-web 模块,做 http 请求。
2、pom.xml 文件中引入 docker 依赖:
- <properties>
- <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
- <java.version>1.8</java.version>
- <!--自定义 docker 镜像前缀,类似 docker.io/mysql 中的 docker.io-->
- <docker.image.prefix>wangmaoxiong.com</docker.image.prefix>
- </properties>
- ...
- <build>
- <plugins>
- <plugin>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-maven-plugin</artifactId>
- </plugin>
-
- <!-- docker 插件,用于 maven 打包时生成 docker 镜像 -->
- <plugin>
- <groupId>com.spotify</groupId>
- <artifactId>docker-maven-plugin</artifactId>
- <version>1.0.0</version>
- <configuration>
- <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
- <!-- dockerfile 配置文件所在的目录-->
- <dockerDirectory>src/main/docker</dockerDirectory>
- <imageTags>${project.version}</imageTags>
- <resources>
- <resource>
- <targetPath>/</targetPath>
- <directory>${project.build.directory}</directory>
- <include>${project.build.finalName}.jar</include>
- </resource>
- </resources>
- </configuration>
- </plugin>
- </plugins>
- </build>
3、在 src/mian 目录下新建 docker 子目录,然后在 docker 目录下创建 dockerfile 文件(不需要后缀名),这个路径需要与 pom.xml 文件中指定的路径一致,内容如下:
- FROM docker.io/java:8
- VOLUME /tmp/tomcat
- ADD java-se-1.0-SNAPSHOT.jar java-se-1.0.jar
- 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 中指定日志存储路径如下:
- <!--文件存储文件设置-->
- <!--fileName:文件存储路径及名称,可以是绝对路径或者相对路径; 存储的永远是最新的日志信息-->
- <!--filePattern:当 fileName 指定的文件大小超过限制,就会根据此文件名规则新建存档目录与文件-->
- <RollingFile name="RollingFileInfo" fileName="/home/wangmx/logs/java-se/java-se.log"
- filePattern="/home/wangmx/logs/java-se/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
- <!--日志文件中日志信息的格式-->
- <PatternLayout pattern="[%d{HH:mm:ss:SSS}] [%p] - [%t] - %l - %m%n"/>
- <Policies>
- <TimeBasedTriggeringPolicy/>
- <!--日志文件大小超过多少时进行存档-->
- <SizeBasedTriggeringPolicy size="500 MB"/>
- </Policies>
- </RollingFile>
5、提供一个控制层访问接口,同时使用 slf4j 记录一些日志,随便写点东西,能访问测试就行。
6、application.yml 配置文件指定 server.port=8317
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 服务了。
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 分钟内的日志
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 容器与宿主服务器文件复制
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。