zoukankan      html  css  js  c++  java
  • Docker Weave网络部署

      Weave在Docker主机之间实现Overlay网络,使用业界标准VXLAN封装,基于UDP传输,也可以加密传输。
    Weave Net创建一个连接多个Docker主机的虚拟网络,类似于一个以太网交换机,所有的容器都连接到这上面,互相通信。
    Weave Net由多个peer组成,Weave路由器运行不同Docker主机上,是一个用户空间的进程;每个peer都有一个名称,重启保持不变。它们通过TCP连接彼此,建立后交换拓扑信息。
    Weave Net可以在具有编号拓扑的部分连接的网络中路由数据包。例如,在下面网络中,peer1直接连接2和3,但是如果1需要发送数据包到4和5,则必须先将其发送到peer3。


    WeaveNet中的”fastdatapath”使用Linux内核的OpenvSwichdatapath模块。该模块使WeaveNet路由器能够告知内核如何处理数据包。OpenvSwichdatapath和VXLAN功能在Linux内核版本3.12+才支持,如果内核不支持,则WeaveNet使用”usermode”数据包路径。WeaveNet会自动选择两台主机之间最快的路径传输数据,提供近原生吞吐量和延迟。

      部署

    使用前提:
    1.确保Linux内核版本3.8+,Docker1.10+。
    2.节点之间如果有防火墙时,必须彼此放行TCP 6783和UDP 6783/6784端口,这是Weave控制和数据端口。
    3.主机名不能相同,通过主机名标识子网。
    

      安装Weave(两个节点均执行)

    curl -L git.io/Weave -o /usr/local/bin/Weave
    chmod +x /usr/local/bin/Weave 
    mv weave /usr/bin/
    chmod +x /usr/bin/weave

       以上安装方法不行使用以下方式安装

    cd /usr/local
    git clone https://github.com/weaveworks/weave
    cd /usr/local/weave/
    cp weave /usr/local/bin/
    

      

      启动并于其他主机连接

    weave launch
    

       会启动并下载镜像

      连接 

    weave launch 192.168.56.129
    #另外一台主机输入
    weave launch 192.168.56.128
    

      

     

    查看路由进程

      节点2连接节点1 连接完就会相互交换本地节点信息

      查看状态

     weave status
    

       

    Version: 2.0.4 (version 2.5.0 available - please upgrade!)
    
            Service: router
           Protocol: weave 1..2
               Name: fe:c2:c3:62:e5:79(docker)
         Encryption: disabled
      PeerDiscovery: enabled
            Targets: 1
        Connections: 1 (1 established)
              Peers: 2 (with 2 established connections)
     TrustedSubnets: none
    
            Service: ipam
             Status: idle
              Range: 10.32.0.0/12
      DefaultSubnet: 10.32.0.0/12
    
            Service: dns
             Domain: weave.local.
           Upstream: 127.0.0.53
                TTL: 1
            Entries: 0
    
            Service: proxy
            Address: unix:///var/run/weave/weave.sock
    
            Service: plugin (legacy)
         DriverName: weave
    

       查看连接信息

     weave status connections
    

      测试互通(本次测试不通)

    docker run -it --net=weave busybox
    

       查看weave分配的网络

    weave ps
    

       weave工作流程

       其他功能

    IP地址管理(IPAM)
    Weave自动为容器分配唯一的IP地址。可通过weave ps查看
    命名和发现
    命名的容器自动会注册到Weave DNS中,并可以通过容器名称访问。
    负载均衡
    允许注册多个相同名称的容器,Weave DNS随机为每个请求返回地址,提供基本的负载均衡功能。
    手动指定IP地址
    docker run –it –e WEAVE_CIDR=10.32.0.100/24 busybox
    动态拓扑
    可以在不停止或重新配置剩余Docker主机的情况下添加主机到Weave网络中或从Weave网络中删除
    容错
    weave peer不断交换拓扑信息,监视和建立与其他peer的网络连接。如果有主机或网络出现故障,Weave会绕过这个主机,保证两边容器可以继续通信,当恢复时,恢复完全连接。
    

     

  • 相关阅读:
    [Java面试一]Spring总结以及在面试中的一些问题.(转发:http://www.cnblogs.com/wang-meng/p/5701982.html)
    微信开发学习2--消息管理
    微信开发学习1--接入指南(入门,微信开发环境搭建)
    Bootstrap学习5--bootstrap中的模态框(modal,弹出层)
    iOS开发常用的宏
    iOS开发之---多线程技术
    iOS开发 之---返回可重用单元格
    iOS开发之---发送邮件
    ios开发之---UITextField退出键盘
    StoryBoard概览
  • 原文地址:https://www.cnblogs.com/minseo/p/10160777.html
Copyright © 2011-2022 走看看