同样是两台服务器:

准备工作: 

设置容器的主机名

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. UML-交互图包含哪些图?

    猫比狗精明,但你无法让8只猫在雪地里拉雪橇---杰夫.瓦尔德斯 本章是重点. 1.总览 2.顺序图 1).类A具有doOne方法和类B的属性 2).doOne方法中调用类B的doTwo()和doThr ...

  2. Linux中的错误重定向你真的懂吗

    在很多定时任务里.shell里我们往往能看到 "2>&1",却不知道这背后的原理. 举个例子: * 1 * * * test.sh > /dev/null 2& ...

  3. 自己做的板子,电脑识别不出下载口(micro-usb),程序无法烧入

    前几天画了一块cortex-A5的底板,出现一个问题,就是通过micro-usb与电脑连接之后,电脑无法识别出来,这就导致程序无法通过micro-usb烧入进去,经过仔细检查硬件,发现第一,元器件都没 ...

  4. 添加头文件的报错failed to emit precompiled header 的解决办法

    在buildsetting中的以下两个路径中添加对应的设置,重现编译即可解决,stackoverflow地址:点击 Solution:1 I added $(inherited) non-recurs ...

  5. shell脚本中的条件测试if中的-z到-d的意思

    文件表达式 if [ -f  file ]    如果文件存在if [ -d ...   ]    如果目录存在if [ -s file  ]    如果文件存在且非空 if [ -r file  ] ...

  6. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第六天】

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  7. 《ECMAScript 6 入门教程 - 阮一峰著》学习笔记

    在刷LeetCode的过程中看到很多新的语法糖,系统学习一下以便代码更加规范,美观,健壮.

  8. mac用python读取文件常见问题(未完成)

    python读取文件常见问题(mac版) 让python的默认编码,和文件的编码保持一致

  9. 代码审计中的SQL注入

    0x00 背景 SQL注入是一种常见Web漏洞,所谓SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令.本文以代码审计的形式研 ...

  10. Outlook邮件的右键菜单中添加自定义按钮

    customUI代码如下: <customUI xmlns="http://schemas.microsoft.com/office/2009/07/customui"> ...