博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
配置Docker多台宿主机间的容器互联
阅读量:6397 次
发布时间:2019-06-23

本文共 2775 字,大约阅读时间需要 9 分钟。

如果要在生产和测试环境大规模采用docker技术,首先就需要解决不同物理机建的docker容器互联问题。本文介绍在centos7环境下采用open vswitch实现不同物理服务器上的docker容器互联的配置。

 

环境介绍:

Server1: 192.168.115.5/24  

Server2: 192.168.115.6/24 

 

一:在Server1Server2上分别用rpm方式安装docker并启动服务

1
2
3
4
# yum list *docker*
# yum -y install docker
# service docker start
Redirecting to /bin/systemctl start  docker.service

Server1Server2上分别安装open vswitch

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# yum -y install wget openssl-devel kernel-devel
# yum groupinstall "Development Tools"
# adduser ovswitch
# su - ovswitch
$ wget http://openvswitch.org/releases/openvswitch-2.3.0.tar.gz
$ tar -zxvpf openvswitch-2.3.0.tar.gz 
$ mkdir -p ~/rpmbuild/SOURCES
$ sed 's/openvswitch-kmod, //g' openvswitch-2.3.0/rhel/openvswitch.spec > openvswitch-2.3.0/rhel/openvswitch_no_kmod.spec
$ cp openvswitch-2.3.0.tar.gz rpmbuild/SOURCES/
  
$ rpmbuild -bb --without check ~/openvswitch-2.3.0/rhel/openvswitch_no_kmod.spec
  
$ exit
  
# yum localinstall /home/ovswitch/rpmbuild/RPMS/x86_64/openvswitch-2.3.0-1.x86_64.rpm
  
#  mkdir /etc/openvswitch
# setenforce 0
  
# systemctl start openvswitch.service
# systemctl  status openvswitch.service -l

三:Server1Server2上建立OVS Bridge并配置路由

Server1: docker容器内网ip网段172.17.1.0/24

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# cat /proc/sys/net/ipv4/ip_forward 
1
# ovs-vsctl add-br obr0
# ovs-vsctl add-port obr0 gre0 -- set Interface gre0 type=gre options:remote_ip=192.168.115.5
  
 
# brctl addbr kbr0
 
# brctl addif kbr0 obr0
 
# ip link set dev docker0 down
 
# ip link del dev docker0
  
# vi /etc/sysconfig/network-scripts/ifcfg-kbr0
ONBOOT=yes
BOOTPROTO=static
IPADDR=172.17.1.1
NETMASK=255.255.255.0
GATEWAY=172.17.1.0
USERCTL=no
TYPE=Bridge
IPV6INIT=no
  
# cat /etc/sysconfig/network-scripts/route-ens32 
172.17.2.0/24 via 192.168.115.6 dev ens32
# systemctl  restart network.service

Server2: docker容器内网ip网段172.17.2.0/24

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# cat /proc/sys/net/ipv4/ip_forward 
1
# ovs-vsctl add-br obr0
# ovs-vsctl add-port obr0 gre0 -- set Interface gre0 type=gre options:remote_ip=192.168.115.6
  
 
# brctl addbr kbr0
 
# brctl addif kbr0 obr0
 
# ip link set dev docker0 down
 
# ip link del dev docker0
  
# vi /etc/sysconfig/network-scripts/ifcfg-kbr0
ONBOOT=yes
BOOTPROTO=static
IPADDR=172.17.2.1
NETMASK=255.255.255.0
GATEWAY=172.17.2.0
USERCTL=no
TYPE=Bridge
IPV6INIT=no
  
# cat /etc/sysconfig/network-scripts/route-ens32 
172.17.1.0/24 via 192.168.115.5 dev ens32
  
# systemctl  restart network.service

:启动容器测试

Server1和Server2上修改docker启动的虚拟网卡绑定为kbr0,重启docker进程

Server1:

# docker run -idt --name test1 registry.fjhb.cn/centos6 /bin/bash 

Server2:

# docker run -idt --name test2 registry.fjhb.cn/centos6 /bin/bash

Server1:

本文转自斩月博客51CTO博客,原文链接http://blog.51cto.com/ylw6006/1606239如需转载请自行联系原作者

ylw6006

你可能感兴趣的文章
XPath 和 LINQ to XML 的比较
查看>>
BizTalk动手实验(十一)自定义开发管道组件
查看>>
智能车学习(十二)——智能车原理
查看>>
C# 多线程join的用法,等待多个子线程结束后再执行主线程
查看>>
Java字节数组转按radix进制输出
查看>>
一句SQL得出表中重复的数据(TMP)
查看>>
软件复用
查看>>
Linux命令之uname
查看>>
也说说学习
查看>>
error CS0234: 命名空间“XXX”中不存在类型或命名空间名称“UserInfoVm”(是否缺少程序集引用?)...
查看>>
了解集合本质必须要知晓的概念02-堆栈
查看>>
AngularJS中获取数据源的几种方式
查看>>
xgboost入门与实战
查看>>
C#发现之旅第五讲 图形开发基础篇
查看>>
HDU 4436 str2int(后缀自动机)
查看>>
Ogre 2011-12-4 合成器框架
查看>>
tcpdump用法
查看>>
读《ASP.NET优化》有感
查看>>
苹果Mac非浪得虚名 安全问题远少Windows PC
查看>>
ajax后退解决方案(一)
查看>>