服务器 
首页 > 服务器 > 浏览文章

最新IDEA快速实现Docker镜像部署运行的过程详解

(编辑:jimmy 日期: 2024/11/19 浏览:3 次 )

背景

使用idea配合docker,实现从javaweb开发,部署,运行全过程。
环境:已经配置好的docker、已经安装好的mysql8容器、一个springBoot 框架的web项目(内含swagger,便于测时)

开启Docker的远程连接

网上的方法找不到对应的docker.service文件,可能版本或者安装方式不同。
通过 systemctl status docker 查找docker.service文件位置:

最新IDEA快速实现Docker镜像部署运行的过程详解

修改/etc/systemd/system/docker.service文件:

#ExecStart=/usr/bin/dockerd
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock

重启Docker服务:

systemctl daemon-reload 
systemctl restart docker.service

2375端口开放:

firewall-cmd --zone=public --add-port=2375/tcp --permanent
firewall-cmd --reload

重启后,验证下2375端口是否是通的:
http://192.168.137.188:2375/info

最新IDEA快速实现Docker镜像部署运行的过程详解

注:这个就表示成功了。

idea docker插件配置

idea 2019 3 版已经集成docker,未集成的请自行安装。

最新IDEA快速实现Docker镜像部署运行的过程详解

注:docker— 点击“+”后,填入连接名称和linux主机ip:docker对外端口

idea连接docker,熟悉相关界面可用操作:

最新IDEA快速实现Docker镜像部署运行的过程详解

注:集成了包括容器,镜像基本的常用命令,具体使用可自己研究,没啥难度。

springboot应用中加入dockerfile

最新IDEA快速实现Docker镜像部署运行的过程详解

注:与pom文件同级目录,文件内容如下:

FROM openjdk:8u212-jre
MAINTAINER aliyu<2557170552@qq.com>

COPY target/myframe-0.0.1-SNAPSHOT.jar /myframe-0.0.1-SNAPSHOT.jar
ENTRYPOINT ["java", "-jar", "/myframe-0.0.1-SNAPSHOT.jar"]

添加docker 运行配置

最新IDEA快速实现Docker镜像部署运行的过程详解

注:1、右键“edit configuration”
2、点击“+”,选择docker
3、选择前面定义的docker连接
4、dockerfile的名称
5、dockerfile的目录位置
6、项目镜像及版本定义
7、run build image 打勾,并命名容器名称,这样可以在创建镜像的后创建容器并运行。
8、配置宿主机与容器的端口映射
9、配置容器固定ip,以避免随机ip导致的类似项目运行找不到服务的问题。固定ip配置请参考:http://blog.java1234.com/blog/articles/628.html
ps:mysql8容器已经配置好默认ip会和这里的ip为同一网段。
10、此处可以预览命令,方便检查错误。
11、配置运行docker run 之前需要重新编译打包项目:

clean package -U -DskipTest -P test

注:因为开发时是主机访问linux内的mysql容器,而应用生成为容器运行时时应用容器访问mysql容器。yml中mysql配置不一致,所以为docker 部署专门使用test yml配置文件。ps:容器间互相访问,请查看“其他-容器间通信”标题
创建好后,可以看到:

最新IDEA快速实现Docker镜像部署运行的过程详解

注:多了一个dockerFile 启动

运行docker 启动配置

点击:

最新IDEA快速实现Docker镜像部署运行的过程详解

注:可以完整的看到maven clean 打包的过程,以及docker 构建镜像,创建并启动容器的过程。甚至可以看到容器启动项目的日志

测试访问swagger主页:

最新IDEA快速实现Docker镜像部署运行的过程详解

其他

容器之间通信

背景:因为不明白容器之间如何通信,导致配置mysql连接时,url一直不对,一直报数据库连接问题。

宿主机ip加映射端口可以访问mysql8容器:
url: jdbc:mysql://192.168.137.188:3307/db_myframe?serverTimezone=GMT

但是myframe 容器内 通过 宿主机ip加映射端口 访问失败
因为容器和容器之间的通信不一样

不能通过localhost:3306 访问,docker容器中的localhost并不是指宿主机的localhost。

docker在运行时建立了虚拟网卡,并命名为docker0
通过 docker inspect mysql8 找到ip地址 172.17.0.2 ,但是注意容器访问容器,端口需要用容器内的端口,而不是映射到宿主机的3307。

上一篇:excel导出在docker环境中总是失败的问题
下一篇:Eclipse创建tomcat实现过程原理详解
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?