springboot docker 部署(详解docker部署SpringBoot及替换jar包的方法)
springboot docker 部署
详解docker部署SpringBoot及替换jar包的方法目录
- 工程目录
- Dockerfile文件
- 文件部署
- 生成镜像
- 启动容器
- 访问WEB
- jar包映射部署
- 脚本部署
- 查看docker日志
- 遇到的问题
关于docker的安装和使用,可以看看之前这两篇文章。docker kubernetes dashboard安装部署详细介绍和Docker如何使用link建立容器之间的连接。这篇文章主要介绍如何在docker上部署springboot项目。关于如何创建springboot项目可以看看这篇文章IDEA上面搭建一个SpringBoot的web-mvc项目遇到的问题
本文主要介绍docker部署springboot的三种方式,分别是:入门方式、jar包替换部署的方式和脚本部署方式,一步步来手把手教程。注意这三种方式的命名是我自创非官方的。
工程目录 Dockerfile文件创建Dockerfile文件,后面会用到。
# Docker image for springboot file run # VERSION 0.0.1 # Author: toutou # 基础镜像使用java FROM java:8 # VOLUME 指定了临时文件目录为/tmp。 # 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp # VOLUME /tmp # 将jar包添加到容器中并更名为app.jar ADD learn-web-0.0.1-SNAPSHOT.jar app.jar # 运行jar包 RUN bash -c 'touch /app.jar' ENTRYPOINT ["java","-jar","/app.jar"] ###声明启动端口号 #EXPOSE 8301
在服务器新建/data/docker/hellolearn文件夹(文件路径可自定义),将maven打包好的jar包和上文中创建的Dockerfile文件复制到服务器新建的文件夹(/data/docker/hellolearn)。
生成镜像docker build -t hellolearn .
docker build -t 镜像名称:标签 Dockerfile的相对位置,点号代表当前目录,不写tag默认是latest。
启动容器docker run -d -p 8301:8301 --name hellolearn hellolearn
docker start hellolearn
-d参数是让容器后台运行;--name为指定容器的名称;-p 是做端口映射,此时将服务器中的8301(冒号前的端口)端口映射到容器中的8301(冒号后的端口)端口(application.properties配置的是8301)
访问WEBjar包映射部署
按照上文的步骤已足可以轻松应对docker部署springboot的全流程。但是这样在启动容器后,每次需更新jar包时,都得重新制作镜像,再重新制作容器。流程及其繁琐,效率极低。那如何在不更新镜像或者容器的前提下直接更新jar包完成部署呢?
5.1 更新Dockerfile
# Docker image for springboot file run # VERSION 0.0.1 # Author: toutou # 基础镜像使用java FROM java:8 EXPOSE 8301 ENTRYPOINT ["java","-jar","/data/learn-web-0.0.1-SNAPSHOT.jar"]
最后一行 ENTRYPOINT ["java","-jar","/data/learn-web-0.0.1-SNAPSHOT.jar"]
会运行容器里/data目录下的learn-web-0.0.1-SNAPSHOT.jar文件。
5.2 使用docker build命令构建镜像
docker build -t hellolearn .
5.3 创建&启动容器
docker run --name hellolearn -it -v /data/docker/newhellolearn/package:/data -d -p 8301:8301 hellolearn
-v 宿主机目录关联容器目录。这样宿主机的/data/docker/newhellolearn/package目录就与docker的/data目录进行映射。
这样的话,当jar包发生变动时,直接更新宿主机的/data/docker/newhellolearn/package目录下的jar包即可,更新jar包之后需要将容器重启一下。
脚本部署通过jar包部署方式引起一个问题,若jar包名字发生变化,比如版本号变化(learn-web-0.0.1-SNAPSHOT.jar-->>learn-web-1.0.1-SNAPSHOT.jar)。需要怎么处理呢?下面就介绍第三种通过脚本部署的方式。
6.1 创建hellolearn.sh文件
java -jar /data/learn-web-0.0.1-SNAPSHOT.jar
将hellolearn.sh上传到/data/docker/hellolearn/scriptdeploy/package,这个文件夹路径可以自定义,记住这个文件夹路径,后面还会用到。
6.2 添加脚本执行权限
chmod +x hellolearn.sh
6.3 创建Dockerfile
# Docker image for springboot file run # VERSION 0.0.1 # Author: toutou # 基础镜像使用java FROM java:8 EXPOSE 8301 CMD ["sh","-c","/data/hellolearn.sh"]
CMD ["sh","-c","/data/hellolearn.sh"]
表示在容器启动时启动6.1中创建的hellolearn.sh脚本。
注意最后一条命令上文中都是ENTRYPOINT,在脚本部署中改成了CMD,至于ENTRYPOINT和CMD的具体区别感兴趣的可以了解一下。
6.4 上传jar包
将jar包放入hellolearn.sh的同一个文件夹目录,即/data/docker/hellolearn/scriptdeploy/package,创建容器时再将该目录(宿主机目录)与容器的/data目录进行映射。。
6.5 文件目录结构图
这里的目录结构不知道大家晕不晕,上传一张我这宿主机的目录结构图,一目了然。
6.6 创建镜像
docker build -t hellolearn-script .
末尾的点号代表当前目录,所以生成镜像的命令需要在Dockerfile所在的目录执行。
6.7 创建&启动容器
docker run --name hellolearn-script -it -v /data/docker/hellolearn/scriptdeploy/package:/data -d -p 8302:8301 hellolearn-script
docker start hellolearn-script
将宿主机的/data/docker/hellolearn/scriptdeploy/package目录与容器的/data目录映射关联。这样的话,当jar包发生变动时,直接更新宿主机目录下的jar包即可。即使jar包名字发生变化,也需要再更新一下hellolearn.sh脚本。更新之后重启容器。
6.8 web测试效果
查看docker日志docker logs [OPTIONS] CONTAINER ID
OPTIONS说明:
-f : 跟踪日志输出
--since :显示某个开始时间的所有日志
-t : 显示时间戳
--tail :仅列出最新N条容器日志
7.1 查看指定时间后的日志,只显示最后100行:
docker logs -f -t --since="2020-10-01" --tail=100 CONTAINER ID
7.2 查个指定时间区段的日志
docker logs -t --since="2020-10-01T19:00:00" --until "2020-10-01T19:00:00" CONTAINER ID
7.3 查看指定时间后面的日志:
docker logs -t --since="2020-10-01T19:00:00" CONTAINER ID
7.4 查看最近5分钟的日志:
docker logs --since 5m CONTAINER ID
7.5 通过 exec 命令对指定的容器执行 bash:
docker exec hellolearn -it /bin/bash
或者 docker exec -it hellolearn bash
7.6 查看docker IP
遇到的问题docker inspect --format='{{.NetworkSettings.IPAddress}}' hellolearn
问题描述:Error response from daemon: driver failed programming external connectivity on endpoint flamboyant_leavitt (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 8301 -j DNAT --to-destination 172.17.0.2:8301 ! -i docker0: iptables: No chain/target/match by that name.
解决方案:重启docker。 systemctl restart docker
具体问题相关信息详见Error response from daemon: driver failed programming external connectivity on endpoint mysql3308 (
源码地址
https://github.com/toutouge/javademosecond/tree/master/hellolearn
到此这篇关于详解docker部署SpringBoot及替换jar包的方法的文章就介绍到这了,更多相关docker部署SpringBoot及替换jar包内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- docker的安装部署(Docker快速安装Zookeeper的详细教程)
- docker容器和主机端口映射(docker利用单个镜像映射到多个端口操作)
- docker-compose部署实例(详解docker-compose速度太慢解决方式)
- 2022-01-25 00:54:18
- docker 命令上传镜像到镜像仓库(Docker 制作镜像Dockerfile和commit操作)
- dockerfile镜像案例(Dockerfile构建自定义镜像的实现)
- docker-compose怎么编写(docker-compose部署php项目实例详解)
- docker 镜像mysql(解决docker拉取mysql镜像太慢的情况)
- docker镜像配置的挂载路径(解决docker挂载的目录无法读写问题)
- docker容器使用流程(在Docker构建的容器中实现安装ping工具)
- docker自动入门教程(Docker Machine深入详解)
- dockerswarm使用教程(Docker Swarm集群管理的使用及原理解析)
- 更改docker容器的ip地址(docker容器通过ping直接运行获取公网IP操作)
- docker是k8s 编排必备容器工具(Docker部署ELK7.3.0日志收集服务最佳实践)
- docker安装教程图解(Docker在线、离线安装及其常用命令操作)
- docker运行镜像端口(docker镜像访问本地elasticsearch端口操作)
- 吉林神秘传染链跨省 传染源尚未找到,舒兰 封城(吉林神秘传染链跨省)
- 吉林舒兰 封城 聚集性疫情传播链已延至沈阳,有一个细节让人忧心(吉林舒兰封城)
- 1天密接者猛增77人,患者轨迹透露危险信号 吉林市全面封闭管理(1天密接者猛增77人)
- 吉林舒兰 封城 15人确诊 276人隔离,出现跨省传播(吉林舒兰封城)
- 四月新番CP人气榜公布,《剃须》两度上榜,沙优不是女朋友(四月新番CP人气榜公布)
- 2019年外媒秋季新番动画角色CP排行榜,桐人和爱丽丝落榜(2019年外媒秋季新番动画角色CP排行榜)
热门推荐
- sqlserver表导入数据(在SQLserver数据库之间进行传表和传数据的图文教程)
- python做学生成绩系统(python学生管理系统)
- SQL Server中@@ROWCOUNT的用法
- 云主机和虚拟主机的区别(云主机有哪些虚拟化技术?)
- nodejs数据采集(nodejs获取表单数据的三种方法实例)
- zabbix数据库解析(zabbix agent2 监控oracle数据库的方法)
- sqlserver维护计划保存在哪(SQL Server误设置max server memory的处理方法)
- php判断类的属性的修饰(PHP whois查询类定义与用法示例)
- docker资源隔离的实现方式(docker配置openGauss数据库的方法详解)
- 阿里云的补丁更新应该怎么打(阿里云安骑士企业版有什么作用?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9