绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
docker 跨主机互联
2020-05-09 11:48:11

docker容器使用weave实现跨主机互联


主机A:192.168.1.9


容器1:192.168.2.1

容器2:192.168.3.1

···


主机B:192.168.1.10


容器1:192.168.2.2

···

实现主机A中容器1与主机B中容器1的网络互联

主机A步骤:

①下载复制weave二进制执行文件(需要internet)

[root@192 ~]#git clone github.com/weaveworks/w #如没有git,yum install git

[root@192 ~]#cp -p /root/weave/weave /usr/local/bin/

[root@192 ~]#weave version

weave version会检测weave运行容器状态,所以会先从注册服务器下载weaveexec容器

②在次weave launch会报各种错误,根据提示先排除错误在进行启动。

[root@192 ~]# iptables -L FORWARD --line-numbers

找到规则REJECT all anywhere anywhere reject-with icmp-host-prohibited的编号将它删除

[root@192 ~]# iptables -D FORWARD 19

打开本地tcp和udp对weave的端口

[root@192 ~]# iptables -I INPUT -m state --state NEW,ESTABLISHED -p tcp --dport 6783 -j ACCEPT

[root@192 ~]# iptables -I INPUT -m state --state NEW,ESTABLISHED -p udp --dport 6783 -j ACCEPT

weave launch会自动进行tls检测,把它关掉启动

[root@192 ~]# weave launch --no-detect-tls

等待下载weave剩下的支持容器

③启动docker容器,使用weave网桥给容器分配沟通地址

[root@192 ~]# docker run -dit -P centos/httpd:v1

[root@192 ~]# weave attach 192.168.2.1/24 容器ID

192.168.2.1

主机B步骤:

①下载复制weave二进制执行文件(需要internet)

[root@192 ~]#git clone github.com/weaveworks/w

[root@192 ~]#cp -p /root/weave/weave /usr/local/bin/

[root@192 ~]#weave version

weave version会检测weave运行容器状态,所以会先从注册服务器下载weaveexec容器

②在次weave launch会报各种错误,根据提示先排除错误在进行启动。

[root@192 ~]# iptables -L FORWARD --line-numbers

找到规则REJECT all anywhere anywhere reject-with icmp-host-prohibited的编号将它删除

[root@192 ~]# iptables -D FORWARD 19

打开本地tcp和udp对weave的端口

[root@192 ~]# iptables -I INPUT -m state --state NEW,ESTABLISHED -p tcp --dport 6783 -j ACCEPT

[root@192 ~]# iptables -I INPUT -m state --state NEW,ESTABLISHED -p udp --dport 6783 -j ACCEPT

weave launch会自动进行tls检测,把它关掉启动

[root@192 ~]# weave launch 192.168.1.9 --no-detect-tls #启动并连接主机A,注意主机A不要去连接主机B

等待下载weave剩下的支持容器

③启动docker容器,使用weave网桥给容器分配沟通地址

[root@192 ~]# docker run -dit -P centos/httpd:v1

[root@192 ~]# weave attach 192.168.2.2/24 容器ID

192.168.2.2

测试:

[root@192 ~]# docker exec -it 容器ID /bin/bash

[root@192 ··]# ping 192.168.2.2

PING 192.168.2.2 (192.168.2.2) 56(84) bytes of data.

64 bytes from 192.168.2.2: icmp_seq=1 ttl=64 time=3.06 ms

64 bytes from 192.168.2.2: icmp_seq=2 ttl=64 time=2.21 ms

跨主机通信成功

分享好友

分享这个小栈给你的朋友们,一起进步吧。

Docker 专区
创建时间:2020-05-08 10:53:18
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • 小雨滴
    专家
戳我,来吐槽~