同样是两台服务器:

准备工作: 

设置容器的主机名

consul:kv类型的存储数据库(key:value)
docker01、02上:
vim  /etc/docker/daemon.json
{
  "hosts":["tcp://0.0.0.0:2376","unix:///var/run/docker.sock"],  这行改了要修改自己的docker配置文件
  "cluster-store": "consul://10.0.0.11:8500",
  "cluster-advertise": "10.0.0.11:2376"     另外一台写自己的ip即可
}
vim /etc/docker/daemon.json
vim /usr/lib/systemd/system/docker.service
ExecStart=/usr/bin/dockerd  --containerd=/run/containerd/containerd.sock  这行改成这样,两台的都要改
systemctl daemon-reload
systemctl restart docker

 docker01上:

docker run -d -p 8500:8500 -h consul --name consul progrium/consul -server -bootstrap  这条命令在设置容器的主机名之后做
[root@docker1 centos_zabbix]# docker images
REPOSITORY                           TAG                 IMAGE ID            CREATED             SIZE
10.0.0.11:5000/kode                  v2                  6914fda5fd44        4 hours ago         502MB
kode                                 v2                  6914fda5fd44        4 hours ago         502MB
10.0.0.11:5000/centos6.9_nginx_ssh   v3                  92b1087df3f5        13 hours ago        431MB
centos6.9_nginx_ssh                  v3                  92b1087df3f5        13 hours ago        431MB
centos6.9_nginx_ssh                  v2                  6307e23ee16d        13 hours ago        431MB
<none>                               <none>              b94c822488f9        13 hours ago        431MB
centos6.9_nginx_ssh                  v1                  f01eeebf918a        13 hours ago        431MB
<none>                               <none>              54167f1d659b        13 hours ago        431MB
<none>                               <none>              71474e616504        13 hours ago        430MB
centos6.9_ssh                        v2                  03387f99f022        14 hours ago        307MB
<none>                               <none>              82d0e9ce844b        14 hours ago        195MB
kode                                 v1                  c0f486ac58fe        15 hours ago        536MB
progrium/consul                      latest              09ea64205e55        4 years ago         69.4MB   这里有了
[root@docker1 centos_zabbix]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED        STATUS                       PORTS                                         NAMES
1016753ee64d        progrium/consul     "/bin/start -server …"   4 minutes ago       Exited (255) 3 minutes ago   53/tcp, 53/udp, 8300-8302/tcp, 8400/tcp, 8301-8302/udp, 0.0.0.0:8500->8500/tcp   consul 

最后在页面上访问:

 

2)创建overlay网络

docker network create -d overlay --subnet 172.16.1.0/24 --gateway 172.16.1.254 ol1  这个网段不能和宿主机上相同,并且随便在一台上执行这个命令即可

 查看容器的网络,有没有出现overlay

[root@docker1 shell]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
e480a4fe5f4b        bridge              bridge              local
0a3cbfe2473f        host                host                local
4e5ccdc657e1        macvlan_1           macvlan             local
aab77f02a0b1        none                null                local
8ae111afded7        ol1                 overlay             global

3)启动容器测试

一台上:
docker run -it --network ol1 --name test01  centos6.9_ssh:v2  /bin/bash
另外一台上:
docker run -it --network ol1 --name test02  centos6.9_ssh:v2  /bin/bash

之后可以通过test01和test02之间联通

  

真实原理:

每个容器有两块网卡,eth0实现容器间的通讯,eth1实现容器访问外网  

  

Dcoker跨主机容器通信之overlay的更多相关文章

  1. centos7下安装docker(15.8docker跨主机容器通信总结)

    性能:underlay网络的性能优于overlay.Overlay网络利用隧道技术,将数据包封装到UDP中进行传输,由于涉及数据包的封装和解封,存在额外的CPU和网络的开销,虽然几乎所有overlay ...

  2. Docker:跨主机容器间通信之overlay [十五]

    一.配置overlay类型网络准备工作 1.在luoahong3主机上 docker run -d -p 8500:8500 -h consul --name consul progrium/cons ...

  3. docker 通过overlay 构建跨主机联网通信

    初始化 swarm meiya@meiya:~$ docker swarm init 将当前节点作为manager节点加入swarm meiya@meiya:~$ docker swarm join- ...

  4. Docker跨主机容器之间的通信macvlan

    找两台测试机: [root@docker1 centos_zabbix]# docker network ls NETWORK ID NAME DRIVER SCOPE 19ac9a55bedb br ...

  5. Weave实现跨主机容器互联

    安装与启动 直接从github下载二进制文件安装. docker_host1(服务器1): 下载weave # sudo wget -O /usr/local/bin/weave https://ra ...

  6. 用flannel实现跨主机container通信

    最近在看kubernetes,看到了网络部分,这部分是集群设计的难点,也是我比较感兴趣的部分.书上提到不同node的container之间通信主要使用flannel,openvswitch等技术,这些 ...

  7. Docker 网络管理及容器跨主机通信

    1.网络模式 docker支持四种网络模式,使用--net选项指定: host,--net=host,如果指定此模式,容器将不会获得一个独立的network namespace,而是和宿主机共用一个. ...

  8. Docker容器跨主机通信之:OVS+GRE

    一.概述 由于docker自身还未支持跨主机容器通信,需要借助docker网络开源解决方案 OVS OpenVSwich即开放式虚拟交换机实现,简称OVS,OVS在云计算领域应用广泛,值得我们去学习使 ...

  9. docker容器跨主机网络overlay

    前提:已部署好docker服务服务预计部署情况如下10.0.0.134 Consul服务10.0.0.135 host1  主机名mcw510.0.0.134 host2  主机名mcw6host1与 ...

随机推荐

  1. Vue2.0权限树组件

    项目使用的饿了么的Element-Ui,权限树使用其树形控件: <el-tree :data="data" ></el-tree> 刚开始没有特殊需求,三级 ...

  2. Scanner方式输入小写字母转换成大写字母

    import java.util.Scanner; /**  * 小写字母转换成大写字母      * @author zzu119  *  */ public class letterTransfe ...

  3. selector的使用,android:clickable="true"

    <ImageView android:id="@+id/patrol_buzzer_btn" android:layout_width="80dp" an ...

  4. PIL对象和numpy三维数组的互相转换

    #https://stackoverflow.com/questions/384759/how-to-convert-a-pil-image-into-a-numpy-array from PIL i ...

  5. day64-html-form表单

    <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8& ...

  6. python机器学习(1:K_means聚类算法)

    一.算法介绍 K-means算法是最简单的也是最著名的划分聚类算法,由于简洁和效率使得他成为所有聚类算法中最广泛使用的.算法的目的是使各个样本与所在均值的误差平方和达到最小(这也是评价K-means算 ...

  7. Python笔记_第三篇_面向对象_5.一个关于类的实例(人开枪射击子弹)

    1. 我们学了类的这些东西,用这些类我们来操作一个关于类的实例. 2. 题目:人开枪射击子弹,然后具有装弹动作,然后再开枪. 第一步:设计类: 人类名:Person属性:gun行为:fire,fill ...

  8. Matlab高级教程_第一篇:Matlab基础知识提炼_01

    第一篇:Matlab基础知识提炼: 这一篇主要用系统和提炼性的语言对Matlab基础知识进行总结,主要适用于有语言基础的学习者.尽量不讲废话. 第一部分:Matlab是什么? 1 Matlab是Mat ...

  9. iOS个人中心渐变动画、微信对话框、标签选择器、自定义导航栏、短信验证输入框等源码

    iOS精选源码 简单的个人中心页面-自定义导航栏并予以渐变动画 程序员取悦女票的正确姿势---Tip1(iOS美容篇) iOS 前台重启应用和清除角标的问题 微信原生提醒对话框3.0 JHLikeBu ...

  10. 14 微服务电商【黑马乐优商城】:day03-springcloud(Zuul网关)

    本项目的笔记和资料的Download,请点击这一句话自行获取. day01-springboot(理论篇) :day01-springboot(实践篇) day02-springcloud(理论篇一) ...