容器之间通信的主要方式

  • 通过容器ip访问

容器重启后,ip会发生变化。通过容器ip访问不是一个好的方案。

  • 通过宿主机的ip:port访问

通过宿主机的ip:port访问,只能依靠监听在暴露出的端口的进程来进行有限的通信。

  • 通过link建立连接(官方不推荐使用)

运行容器时,指定参数link,使得源容器与被链接的容器可以进行相互通信,并且接受的容器可以获得源容器的一些数据,比如:环境变量。

# 源容器
docker run -itd --name container -e MYSQL_ROOT_PASSWORD=root mysql:5.7
#被链接容器 
docker run -itd --name container --link test-mysql:mysql  centos /bin/bash
#进入容器
docker exec -it container /bin/bash
  • 通过 User-defined networks(推荐)

docker network来创建一个桥接网络,在docker run的时候将容器指定到新创建的桥接网络中,这样同一桥接网络中的容器就可以通过互相访问。

docker run -it --network network --network-alias mysql  -e MYSQL_ROOT_PASSWORD=123 mysql:5.7

启动被链接的容器

docker run -it --network test-network --network-alias centos  centos /bin/bash

Docker宿主机与容器通信

首先是关于防火墙的问题,可以查看本地自己的防火墙配置,可以关闭防火墙继续下部操作

对于宿主机与容器无法通信的,因为默认的容器网络是采用bridge的桥接形式,会在容器内部开辟自己的网段,所以,你接下来需要用到的几个命令如下:

ifconfig
查看下你本地的docker网络配置
docker network inspect [你容器挂载的network]
查看你的容器网络分段ip地址
route -n 
查看你的本地容器地址




docker0 ping不通 docker容器ping不通_Powered by 金山文档


docker0 ping不通 docker容器ping不通_mysql_02


docker0 ping不通 docker容器ping不通_Powered by 金山文档_03


查看下你本地network网络是不是与我的一致,如果你想修改你本地network网段,可以做下面操作

"default-address-pools" : [
    {
      "base" : "192.168.1.0/8",
      "size" : 24
    }
  ]

指定你的网段192.168.1.0/8,size:24,本地就会设置192.0.0.1的docker网段,记住修改后需要重新启动docker

systemctl restart docker

你可以将之前的network删除,本地重新创建一个network再次查看你创建的network的网段地址,就会发生变化