Docker:跨主机通讯

修改主机docker默认的虚拟网段,而后在各自主机上分别把对方的docker网段加入到路由表中,配合iptables便可实现docker容器夸主机通讯。配置方法以下:html

设有三台虚拟机docker

  • v1: 10.108.8.200
  • v2: 10.108.8.205
  • v3: 10.108.8.202

更改虚拟机docker0网段,v1为172.17.1.1/24,v2为172.17.2.1/24,v3为172.17.3.1/24shell

#v1
sudo ifconfig docker0 172.17.1.1 netmask 255.255.255.0
sudo bash -c 'echo DOCKER_OPTS="-B=docker0" >> /etc/default/docker'
sudo service docker restart
# v2
sudo ifconfig docker0 172.17.2.1 netmask 255.255.255.0
sudo bash -c 'echo DOCKER_OPTS="-B=docker0" >> /etc/default/docker'
sudo service docker restart
# v3
sudo ifconfig docker0 172.17.3.1 netmask 255.255.255.0
sudo bash -c 'echo DOCKER_OPTS="-B=docker0" >> /etc/default/docker'
sudo service docker restart

而后在v1上把v2的docker虚拟网段加入到路由表中,在v2上将v1的docker虚拟网段加入到本身的路由表中bash

# v1 10.108.8.200
sudo route add -net 172.17.2.0 netmask 255.255.255.0 gw 10.108.8.205
sudo iptables -t nat -F POSTROUTING
> sudo iptables -t nat -A POSTROUTING -s 172.17.1.0/24 ! -d 172.17.0.0/16 -j MASQUERADE
# v2 10.108.8.205   v3   10.108.8.202
sudo route add -net 172.17.1.0  netmask 255.255.255.0  gw 10.108.8.200
sudo iptables -t nat -F POSTROUTING
sudo iptables -t nat -A POSTROUTING -s 172.17.2.0/24 ! -d 172.17.0.0/16 -j MASQUERADE

至此,两台虚拟机中的docker容器能够互相访问了。rest

原文地址:https://www.35youth.cn/531.htmlcode

相关文章
相关标签/搜索