docker跨主机通信方式二 OpenvSwitch

目前市面上跨主机通信第三方主流的解决方法有flannel, weave, Pipework, OpenvSwitch等

这里使用OpenvSwitch,它实现比较简单,成熟且功能强大。

架构图如下:


实验环境:

一、基础环境设置

docker1

1. 配置固定IP

[root@localhost ~]#  vim  /etc/sysconfig/network-scripts/ifcfg-ens32

TYPE=Ethernet

PROXY_METHOD=none

BROWSER_ONLY=no

BOOTPROTO=static

DEFROUTE=yes

IPV4_FAILURE_FATAL=no

IPV6INIT=yes

IPV6_AUTOCONF=yes

IPV6_DEFROUTE=yes

IPV6_FAILURE_FATAL=no

NAME=ens32

UUID=75963e3f-b289-4bbd-8489-44f6f2b8c7f0

DEVICE=ens32

ONBOOT=yes

IPADDR=192.168.0.10

PREFIX=24

GATEWAY=192.168.0.1

DNS1=114.114.114.114

[root@localhost ~]# systemctl restart network

2. 更改主机名

[root@localhost ~]#  hostnamectl set-hostname docker1

[root@localhost ~]#  exit    //重新登陆即可

[root@docker1 ~]#

3.关闭防火墙

[root@docker1 ~]# systemctl stop firewalld

[root@docker1 ~]# systemctl disable firewalld

4. 同步系统时间

[root@docker1 ~]# yum -y install ntp

[root@docker1 ~]#  systemctl enable ntpd.service

[root@docker1 ~]# ntpdate cn.pool.ntp.org

[root@docker1 ~]# hwclock -w

[root@docker1 ~]#  crontab -e

0 2 * * * ntpdate ntpdate cn.pool.ntp.org  && hwclock -w

5. 安装docker

[root@docker1 ~]# yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

[root@docker1 ~]# yum install -y docker-ce

[root@docker1 ~]# systemctl start docker

[root@docker1 ~]# systemctl enable docker

6. 安装网桥bridge-utils

[root@docker1 ~]#  yum -y install bridge-utils

7.关闭selinux

[root@docker1 ~]# vim /etc/sysconfig/selinux

SELINUX=disabled

[root@docker1 ~]#  reboot


docker2

1. 配置固定IP

[root@localhost ~]#  vim  /etc/sysconfig/network-scripts/ifcfg-ens32

TYPE=Ethernet

PROXY_METHOD=none

BROWSER_ONLY=no

BOOTPROTO=static

DEFROUTE=yes

IPV4_FAILURE_FATAL=no

IPV6INIT=yes

IPV6_AUTOCONF=yes

IPV6_DEFROUTE=yes

IPV6_FAILURE_FATAL=no

IPV6_ADDR_GEN_MODE=stable-privacy

NAME=ens32

UUID=75963e3f-b289-4bbd-8489-44f6f2b8c7f0

DEVICE=ens32

ONBOOT=yes

IPADDR=192.168.0.10

PREFIX=24

GATEWAY=192.168.0.1

DNS1=114.114.114.114

[root@localhost ~]# systemctl restart network

2. 更改主机名

[root@localhost ~]#  hostnamectl set-hostname docker2

[root@localhost ~]#  exit    //重新登陆即可

[root@docker2~]#

3.关闭防火墙

[root@docker2~]# systemctl stop firewalld

[root@docker2~]# systemctl disable firewalld

4. 同步系统时间

[root@docker2~]# yum -y install ntp

[root@docker2~]# systemctl enable ntpd.service

[root@docker2~]# ntpdate cn.pool.ntp.org

[root@docker2~]# hwclock -w

[root@docker2~]# crontab -e

0 2 * * * ntpdate ntpdate cn.pool.ntp.org  && hwclock -w

5. 安装docker

[root@docker2~]# yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

[root@docker2~]# yum install -y docker-ce

[root@docker2~]# systemctl start docker

[root@docker2~]# systemctl enable docker

6. 安装网桥bridge-utils

[root@docker2~]#  yum -y install bridge-utils

7.关闭selinux

[root@docker2~]# vim /etc/sysconfig/selinux

SELINUX=disabled

[root@docker2~]#  reboot


二、openvswitch安装配置

docker1配置

1.安装依赖

[root@docker1 ~]# yum -y install make gcc openssl-devel autoconf automake rpm-build redhat-rpm-config  python-devel openssl-devel kernel-devel kernel-debug-devel libtool wget

2. 预处理

[root@docker1 ~]# cd /usr/local/src/

[root@docker1 src]# mkdir -p ~/rpmbuild/SOURCES

[root@docker1 src]# wget http://openvswitch.org/releases/openvswitch-2.9.0.tar.gz

[root@docker1 src]#  cp openvswitch-2.9.0.tar.gz ~/rpmbuild/SOURCES/

[root@docker1 src]#  tar xf openvswitch-2.9.0.tar.gz

[root@docker1 src]# sed 's/openvswitch-kmod, //g' openvswitch-2.9.0/rhel/openvswitch.spec > openvswitch-2.9.0/rhel/openvswitch_no_kmod.spec

3. 构建rpm包

[root@docker1 src]# rpmbuild -bb --nocheck ./openvswitch-2.9.0/rhel/openvswitch_no_kmod.spec

//系统有报错

error: Failed build dependencies:

python-six is needed by openvswitch-2.9.0-1.x86_64

selinux-policy-devel is needed by openvswitch-2.9.0-1.x86_64

python-sphinx is needed by openvswitch-2.9.0-1.x86_64

原因:还需要安装以下依赖

[root@docker1 src]# yum  -y  install  python-six selinux-policy-devel  python-sphinx

4. 安装

[root@docker1 src]# cd ~

[root@docker1 ~]# yum -y install  ~/rpmbuild/RPMS/x86_64/openvswitch-devel-2.9.0-1.x86_64.rpm

//将生成的RPM包openvswitch-devel-2.9.0-1.x86_64.rpm拷贝到docker2上,到时后docker2可以直接安装使用

5.  启动openvswitch服务

[root@docker1 ~]# systemctl start openvswitch.service

[root@docker1 ~]# systemctl enable openvswitch.service

[root@docker1 ~]# systemctl status openvswitch.service




docker2配置

1. 将docker1生成的openvswitch-2.9.0-1.x86_64.rpm拷贝到docker2后直接yum安装

[root@docker2 ~]# scp -r root@192.168.0.10:/root/rpmbuild/SOURCES//root/rpmbuild/RPMS/x86_64/openvswitch-2.9.0-1.x86_64.rpm  .

[root@docker2 ~]#  yum -y install openvswitch-2.9.0-1.x86_64.rpm

2. 启动openvswitch服务

[root@docker2 ~]# systemctl start openvswitch.service

[root@docker2 ~]# systemctl enable openvswitch.service

[root@docker2 ~]# systemctl status openvswitch.service


三、跨主机通信

docker1

1. 开启路由转发功能

[root@docker1 ~]# vim /etc/sysctl.conf

net.ipv4.ip_forward = 1

[root@docker1 ~]# sysctl -p

net.ipv4.ip_forward = 1

2. 修改docker默认网段(即docker0网段,默认是172.17.0.0/24)

[root@docker1 ~]#  vim  /etc/docker/daemon.json

{

  "registry-mirrors": ["https://4zy0t91p.mirror.aliyuncs.com"],  //阿里docker加速器配置

   "bip": "10.0.0.1/24"  //docker0网段修改

}

3. 建立OVS Bridge

1.> 在两个主机上创建隧道网桥br0,并通过gre0协议创建隧道

[root@docker1 ~]#  ovs-vsctl add-br br0

[root@docker1 ~]# ovs-vsctl  add-port  br0  gre0  --  set Interface gre0 type=gre options:remote_ip=192.168.0.10

2.> 将br0作为接口并纳入docker0网桥

[root@docker1 ~]# brctl addif docker0  br0

4. 配置路由

作用:用于转发到其它宿主机上docker容器,其中ens32为真实的网卡设备名称,需要根据实际网卡设备名称配置

在docker1上添加路由表,使docker1能到达docker2定义的10.0.1.0/24网段,意思是告诉docker1主机 10.0.1.0/24网段的ip在192.168.0.20的docker2上。

[root@docker1 ~]# vim  /etc/sysconfig/network-scripts/route-ens32

10.0.1.0/24 via 192.168.0.20 dev ens32

5. 重启docker服务并查看

[root@docker1 ~]# systemctl daemon-reload

[root@docker1 ~]# systemctl restart docker

[root@docker1 ~]# systemctl restart network     //这三步很关键,要依次重启

[root@docker1 ~]# brctl show

bridge name bridge id STP enabled interfaces

docker0 8000.0242d78c3863 no br0

[root@docker1 ~]# route  -n

Kernel IP routing table

Destination    Gateway        Genmask        Flags Metric Ref    Use Iface

0.0.0.0        192.168.0.1    0.0.0.0        UG    100    0        0 ens32

10.0.0.0      0.0.0.0        255.255.255.0  U    0      0        0 docker0

10.0.1.0      192.168.0.20    255.255.255.0  UG    100    0        0 ens32

192.168.0.0    0.0.0.0        255.255.255.0  U    100    0        0 ens32

[root@docker1 ~]# ifconfig

docker0: flags=4099  mtu 1500

        inet 10.0.0.1  netmask 255.255.255.0  broadcast 10.0.10.255

        inet6 fe80::42:d7ff:fe8c:3863  prefixlen 64  scopeid 0x20

        ether 02:42:d7:8c:38:63  txqueuelen 0  (Ethernet)

        RX packets 6  bytes 392 (392.0 B)

        RX errors 0  dropped 0  overruns 0  frame 0

        TX packets 14  bytes 1124 (1.0 KiB)

        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

6. 测试网络

[root@docker1 ~]# docker pull cirros

[root@docker1 ~]# docker run -it cirros /bin/sh

1.> 查看网络

[root@c778cae8a2e5 /]# ifconfig

eth0      Link encap:Ethernet  HWaddr 02:42:0A:00:0A:02 

          inet addr:10.0.0.2  Bcast:10.0.10.255  Mask:255.255.255.0

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

          RX packets:3 errors:0 dropped:0 overruns:0 frame:0

          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:0

          RX bytes:258 (258.0 B)  TX bytes:0 (0.0 B)

2.> ping外网

[root@c778cae8a2e5 /]# ping www.baidu.com

PING www.baidu.com (61.135.169.121): 56 data bytes

64 bytes from 61.135.169.121: seq=0 ttl=56 time=4.502 ms

64 bytes from 61.135.169.121: seq=1 ttl=56 time=8.104 ms

...

3.> ping docker1宿主机

[root@c778cae8a2e5 /]# ping 192.168.0.10

PING 192.168.0.10 (192.168.0.10): 56 data bytes

64 bytes from 192.168.0.10: seq=0 ttl=63 time=0.414 ms

64 bytes from 192.168.0.10: seq=1 ttl=63 time=0.692 ms

...

4.> ping docker2宿主机

[root@c778cae8a2e5 /]# ping 192.168.0.20

PING 192.168.0.20 (192.168.0.20): 56 data bytes

64 bytes from 192.168.0.20: seq=0 ttl=63 time=0.414 ms

64 bytes from 192.168.0.20: seq=1 ttl=63 time=0.692 ms

...



docker2

1. 开启路由转发功能

[root@docker2 ~]# vim /etc/sysctl.conf

net.ipv4.ip_forward = 1

[root@docker2 ~]# sysctl -p

net.ipv4.ip_forward = 1

2. 修改docker默认网段(即docker0网段,默认是172.17.0.0/24)

[root@docker2 ~]#  vim  /etc/docker/daemon.json

{

  "registry-mirrors": ["https://4zy0t91p.mirror.aliyuncs.com"],  //阿里docker加速器配置

   "bip": "10.0.1.1/24"  //docker0网段修改

}

3. 建立OVS Bridge

1.> 在两个主机上创建隧道网桥br0,并通过gre0协议创建隧道

[root@docker2 ~]#  ovs-vsctl add-br br0

[root@docker2 ~]# ovs-vsctl add-port br0 gre0   --   set Interface gre0 type=gre options:remote_ip=192.168.0.20

2.> 将br0作为接口并纳入docker0网桥

[root@docker2 ~]# brctl addif docker0  br0

4. 配置路由

作用:用于转发到其它宿主机上docker容器,其中ens32为真实的网卡设备名称,需要根据实际网卡设备名称配置

在docker2上添加路由表,使docker2能到达docker1定义的10.0.0.0/24网段,意思是告诉docker2主机 10.0.0.0/24网段的ip在192.168.0.10的docker1上。

[root@docker2 ~]# vim  /etc/sysconfig/network-scripts/route-ens32

10.0.0.0/24 via 192.168.0.10 dev ens32

5. 重启docker服务并查看

[root@docker2 ~]# systemctl daemon-reload

[root@docker2 ~]# systemctl restart docker

[root@docker2 ~]# systemctl restart network     //这三步很关键,要依次重启

[root@docker2 ~]# brctl show

bridge name bridge id STP enabled interfaces

docker0 8000.0242d78c3863 no br0

[root@docker2 ~]# route -n

Kernel IP routing table

Destination    Gateway        Genmask        Flags Metric Ref    Use Iface

0.0.0.0        192.168.0.1    0.0.0.0        UG    100    0        0 ens32

10.0.1.0      0.0.0.0        255.255.255.0  U    0      0        0 docker0

10.0.0.0      192.168.0.10    255.255.255.0  UG    100    0        0 ens32

192.168.0.0    0.0.0.0        255.255.255.0  U    100    0        0 ens32

[root@docker2 ~]# ifconfig

docker0: flags=4099  mtu 1500

        inet 10.0.1.1  netmask 255.255.255.0  broadcast 10.0.10.255

        inet6 fe80::42:d7ff:fe8c:3863  prefixlen 64  scopeid 0x20

        ether 02:42:d7:8c:38:63  txqueuelen 0  (Ethernet)

        RX packets 6  bytes 392 (392.0 B)

        RX errors 0  dropped 0  overruns 0  frame 0

        TX packets 14  bytes 1124 (1.0 KiB)

        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

6.  测试网络

[root@docker2 ~]# docker pull cirros

[root@docker2 ~]# docker run -it cirros /bin/sh

1.> 查看网络

[root@d2b2a56abf59 /]#  ifconfig

eth0      Link encap:Ethernet  HWaddr 02:42:0A:00:0A:02 

          inet addr:10.0.1.2  Bcast:10.0.10.255  Mask:255.255.255.0

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

          RX packets:3 errors:0 dropped:0 overruns:0 frame:0

          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:0

          RX bytes:258 (258.0 B)  TX bytes:0 (0.0 B)

2.> ping外网

[root@d2b2a56abf59 /]#  ping www.baidu.com

PING www.baidu.com (61.135.169.121): 56 data bytes

64 bytes from 61.135.169.121: seq=0 ttl=56 time=4.502 ms

64 bytes from 61.135.169.121: seq=1 ttl=56 time=8.104 ms

...

3.> ping docker2宿主机

[root@d2b2a56abf59 /]#  ping 192.168.0.20

PING 192.168.0.20 (192.168.0.20): 56 data bytes

64 bytes from 192.168.0.20: seq=0 ttl=63 time=0.414 ms

64 bytes from 192.168.0.20: seq=1 ttl=63 time=0.692 ms

...

4.> ping docker1宿主机

[root@d2b2a56abf59 /]#  ping 192.168.0.10

PING 192.168.0.10 (192.168.0.10): 56 data bytes

64 bytes from 192.168.0.10: seq=0 ttl=63 time=0.414 ms

64 bytes from 192.168.0.10: seq=1 ttl=63 time=0.692 ms

...



5.> 容器互ping

在docker1的容器中ping docker2中的容器

[root@c778cae8a2e5 /]# ping 10.0.1.2

PING 10.0.1.2 (10.0.1.2): 56 data bytes

64 bytes from 10.0.1.2: seq=0 ttl=62 time=0.316 ms

64 bytes from 10.0.1.2: seq=1 ttl=62 time=0.813 ms

...

在docker2的容器中ping docker1中的容器

[root@d2b2a56abf59 /]#  ping 10.0.0.2

PING 10.0.0.2 (10.0.0.2): 56 data bytes

64 bytes from 10.0.0.2: seq=0 ttl=63 time=0.414 ms

64 bytes from 10.0.0.2: seq=1 ttl=63 time=0.692 ms

...

上述证明:容器与容器之间、容器与宿主机、容器与外网都是通的


原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容

  • pipework的做法是通过网桥使容器,宿主机在同一个网段中进行通信 实验环境: 一、基础环境配置,三台服务器均执...
    向上的路阅读 2,994评论 1 2
  • 本文整理了在实践过程中使用的Linux网络工具,这些工具提供的功能非常强大,我们平时使用的只是冰山一角,比如lso...
    老夫刘某阅读 3,509评论 0 7
  • 试了下比较流行的几种SDN,感觉flannel还是比较好用,这里简单记录一下。 用的是virtualbox,3个机...
    jony456123阅读 953评论 0 1
  • 概况 掌握 Docker 在Centos的安装: 操作系统:Win 10 家庭中文版 虚拟机软件:Oracle V...
    andy0898阅读 1,100评论 1 9
  • 家里70岁的老奶奶每次见到我都要念叨着,我家这个小娃娃啊,快点结婚吧。每次听到这些话,我一定是不耐烦的,大声吵着我...
    七友以你阅读 496评论 3 2