通过前面的学习,我们已经可以把自己写的微服务项目通过dockerfile文件方式部署到docker上面了。那么微服务之间通信,怎么通信的?是在同一个网络还是在不同的网络环境下?docker中怎么配置网络环境呢?本文咱们就一起学学docker网络。
在不启动docker之前,我们来看看宿主机的网络情况。使用命令:ifconfig
说明:
ens33:是宿主机的ip.比如我们想通过我们物理机Windows连接到虚拟机宿主机的话,就是用的是这个ip.
lo:local,本地地址。
virbro:centos在虚拟化的时候,会安装一个以网桥连接的私网地址。默认就是192.168.122.1。是做虚拟机网桥使用的。
启动docker后,在查看宿主机网络情况.命令依然是ifconfig
我们发现会多出一个 docker0的网卡。这个就是本章节需要讲解的。
使用命令查看:
docker network ls
bridge、host、none是默认创建的3大网络模式。
我们先来help下,看看docker network都有哪些命令
命令:
查看命令:
网络模式
docker网络有以下几种模式:
其中比较常用的是bridge和host模式。
先启动两个ubuntu
查看网络情况:
docker inspect u1
或者只查看倒数20行
docker inspect ul | tail -n 20
我们再来看看u2的网络设置
假设我们把uw rm -f
然后我们在启动一个u3
再来看看U3的ip:
哇哦!ip是0.3。我们发现这个时候u3的ip竟然复用了u2的ip.这是多么可怕。
比如,在实际中,u2上面安装的是mysql.u2宕机后,创建了u3,向redis集群使用。但是,项目中写的ip还是172.17.0.3来连接数据库。那么u3启动后,是redis服务。程序连接MySQL也来找0.3。是不是很可怕。所以,在服务中,写死ip的需要注意。
所以,在实际中,我们在规划服务的时候,ip应该写死的。
那么怎么处理呢?我们会用到
docker network create 网络名称