同样是两台服务器:

准备工作: 

设置容器的主机名

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. Ubuntu---Git

    本篇文章简单总结了常用 Git 的使用 前言 设置用户信息 1, Git 是分布式的 SSH 代码管理工具,远程的代码管理是基于 SSH 的,所以要使用远程的 Git 则需要 SSH 的配置. ste ...

  2. PAT Advanced 1020 Tree Traversals (25) [⼆叉树的遍历,后序中序转层序]

    题目 Suppose that all the keys in a binary tree are distinct positive integers. Given the postorder an ...

  3. python学习笔记-字符串的拼接

    1.百分号方式拼接 %[(name)][flags][width].[precision]typecode (name)      可选,用于选择指定的key flags          可选,可供 ...

  4. nginx中rewrite flag

    rewrite  正则表达式  新URI  [flag]; [flag] 选项用于调控重写的行为,它的取值可能是: last:重写完成后,会停止继续处理当前区块所有属于ngx_http_rewrite ...

  5. Linux 标准IO库介绍

    1.标准IO和文件IO有什么区别? (1).看起来使用时都是函数,但是:标准IO是C库函数,而文件IO是Linux系统的API. (2).C语言库函数是由API封装而来的.库函数内部也是通过调用API ...

  6. Proe 导出PDF Vb.net

    Private Sub btnStart_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnSt ...

  7. jdk8下载地址

    http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html Java SE Binaries ...

  8. uboot 编译

    . 解包u-boot源码包(u-boot-2016.07) . 配置交叉编译器 根据内核编译里的步骤配置 . 编译uboot yum install ncurses* // ncurses是个终端的图 ...

  9. [LC] 348. Design Tic-Tac-Toe

    Design a Tic-tac-toe game that is played between two players on a nx n grid. You may assume the foll ...

  10. 吴裕雄--天生自然 JAVA开发学习:多线程编程

    class RunnableDemo implements Runnable { private Thread t; private String threadName; RunnableDemo( ...