美文网首页思科DNA思科DX80
docker跨主机通信方式二 OpenvSwitch

docker跨主机通信方式二 OpenvSwitch

作者: 向上的路 | 来源:发表于2018-05-22 18:02 被阅读285次

    目前市面上跨主机通信第三方主流的解决方法有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

    ...

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


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

    相关文章

      网友评论

        本文标题:docker跨主机通信方式二 OpenvSwitch

        本文链接:https://www.haomeiwen.com/subject/gqrkjftx.html