1、Docker集群网络配置之Weave

  Weave是Github上一个比较热门的Docker容器网络方案,具有非常良好的易用性且功能强大。仓库地址:https://github.com/weaveworks/weave.git。

  Weave由两大主要组件组成:

    Weave:用户态shell脚本,用于安装Weave,将container连接到Weave虚拟网络,并为他们分配IP。

    Weaver:运行于container内,每个Weave网络内的主机都要运行,它是一个Go语言实现的虚拟网络路由器,不同主机之间的网络通信都依赖于Weaver路由。

  Weave简单使用:

    Host1

      启动Weave:weave launch

      启动容器:weave run 10.2.1.1/24 -t -i ubuntu bash

    Host2

      启动Weave并连接Host1:weave launch $Host1-IP

      启动容器:weave run 10.2.1.2/24 -t -i ubuntu bash

    测试两个容器之间可以通信。

  Weave其他命令:

    weave launch [-password] [-nickname]:启动时设置节点之间互通的密码

    weave connect $OTHER_HOST_IP:连接其他weave host主机

    weave attach IP $ID:将已经运行的容器动态添加到网络,detach命令为剥离

    weave ps:查看containers列表

    weave status:查看weave状态

  Weave缺点:

    不支持服务发现,主机不能动态加入节点网络,只能手动通过weave launch或connect加入weave网络

    不支持动态分配IP

2、Docker集群网络配置之Flannel

  安装:从https://github.com/coreos/flannel/releaseshttps://github.com/coreos/etcd/releases分别下载Flannel和Etcd的最新版本二进制包。
  解压后将Flannel的二进制文件“flanneld”和脚本文件“mk-docker-opts.sh”、以及Etcd的二进制文件“etcd”和“etcdctl”放到系统的PATH目录下即可。

  创建集群:

    Host1:IP 172.16.10.189

      etcd -name infra0 -initial-advertise-peer-urls http://172.16.10.189:2380 -listen-peer-urls  http://172.16.10.189:2380 -initial-cluster-token etcd-cluster-1 -initial-cluster infra0=http://172.16.10.189:2380,infra1=http://172.16.10.88:2380 -initial-cluster-state new

    Host2:IP 172.16.10.88

      etcd -name infra1 -initial-advertise-peer-urls http://172.16.10.88:2380 -listen-peer-urls  http://172.16.10.88:2380 -initial-cluster-token etcd-cluster-1 -initial-cluster infra0=http://172.16.10.189:2380,infra1=http://172.16.10.88:2380 -initial-cluster-state new

  查看集群成员列表(任一主机都可):  

    [root@kvm ~]# etcdctl member list
    5b2b3a252a3f1a96: name=infra1 peerURLs=http://172.16.10.88:2380 clientURLs=http://localhost:2379 isLeader=false
    70b69a104d137154: name=infra0 peerURLs=http://172.16.10.189:2380 clientURLs=http://localhost:2379 isLeader=true

  写入Flannel网络配置

    etcdctl mkdir /coreos.com/network/

    etcdctl set /coreos.com/network/config '{"Network":"10.1.0.0/16","SubnetLen":24,"SubnetMin":"10.1.0.0","SubnetMax":"10.1.128.0"}'

  每台主机都运行flanneld

  每台主机重新配置docker

    sudo mk-docker-opts.sh -i
    source /run/flannel/subnet.env
    sudo rm /var/run/docker.pid
    sudo ifconfig docker0 ${FLANNEL_SUBNET} 
  重启docker进程,之后在启动容器,此时主机1和2的容器互通 3、Docker集群网络配置之SocketPlane
  仓库地址:https://github.com/socketplane/socketplane
  SocketPlane的安装配置比较简单,只需要运行源码目录下的scripts/install.sh就可安装。
  会下载SocketPlane和Powerstrip两个镜像,以容器的方式运行SocketPlane主程序。
  查看SocketPlane运行是否正常
  docker ps  #显示socketplane正在运行
  socketplane agent logs  #日志无异常,满足这两个条件即运行正常
  创建socketplane网络:socketplane network create frontend 192.168.0.1/24
  创建一个名为frontend,IP段为192.168.0.1/24的子网。
  查看当前集群内包含几个子网:socketplane network list,结果以集合的方式的显示
  利用socketplane启动容器:socketplane run -n frontend -tid ubuntu:latest bash
  进去容器查看网络:docket exec -ti $ID ip addr show
  可看到容器自动从frontend子网获取了一个IP,socketplane底层使用consul同步数据,保证IP不冲突
  查看socketplane信息:socketplane info

Docker(六):Docker网络配置进阶的更多相关文章

  1. docker系列之网络配置

    docker 网络配置 docker 安装后, 会自动在系统做一个网桥配置 docker0 . 其容器都会分配到此网桥配置下的独立, 私有 IP 地址. 如果你要自己配置桥接, 也可以把 docker ...

  2. 【爬坑系列】之docker的overlay网络配置(未完,待续)

    理论知识储备: 想了解vxlan网络的知识:https://www.cnblogs.com/shuiguizi/p/10923841.html 想了解docker网络的原理知识:https://www ...

  3. Docker网络配置进阶

    Docker启动会默认创建docker0虚拟网桥,是Linux的一个bridge,可以理解成一个软件交换机.它会在挂载到它的网口之间进行转发. 之后所有容器都是在172.17.0.x的网段上,并且可以 ...

  4. docker 容器间网络配置

    创建一个docker容器,docker系统会自动为该容器分配一个ip地址,通常是172.17开头. 我们可以在主机上用 docker inspect 命令 或者进入容器用ifconfig命令来查看容器 ...

  5. docker网络配置方法总结

    docker启动时,会在宿主主机上创建一个名为docker0的虚拟网络接口,默认选择172.17.42.1/16,一个16位的子网掩码给容器提供了65534个IP地址.docker0只是一个在绑定到这 ...

  6. 高级网络功能(Docker支持的网络定制配置)

    网络的高级知识,包括网络的启动和配置参数.DNS的使用配置.容器访问和端口映射的相关实现. 在一些具体场景中,Docker支持的网络定制配置,通过Linux命令来调整.补充.甚至替换Docker默认的 ...

  7. Docker Network Configuration 高级网络配置

    Network Configuration TL;DR When Docker starts, it creates a virtual interface named docker0 on the ...

  8. Docker 四种网络模式

    原文 https://www.cnblogs.com/gispathfinder/p/5871043.html 我们在使用docker run创建Docker容器时,可以用--net选项指定容器的网络 ...

  9. 网络配置——Linux运维基础

    今天把Linux的网络配置总结了一下,尽管并不难可是是个比較重要的基础.然后我也不知到自己以后是否会做运维,可是我知道自己比較喜欢刨根问底.还有就是我很珍惜我以前掌握过的这些运维的技能.今天突然间问自 ...

随机推荐

  1. 一个非常好用的图片切割工具(c# winform开发) 附源码

    本人业余时间开发了一个图片切割工具,非常好用,也很灵活! 特别对大型图片切割,更能体现出该软件的优势! 开发工具为winform,源码下载地址:http://download.csdn.net/dow ...

  2. hdu 3829 Cat VS Dog 二分匹配 最大独立点集

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3829 题目大意: 给定N个猫,M个狗,P个小朋友,每个小朋友都有喜欢或者不喜欢的某猫或者某狗 管理员从 ...

  3. UWP 共享文件——发送者

    这一节,顾名思义,即使你要共享数据给别人,你是数据的提供者.分两步即可1.直接复制代码 protected override void OnNavigatedTo(NavigationEventArg ...

  4. C#自定义ip控件

    前言:由于项目中有ip输入,但C#中又没有IP控件,如果直接放4个TextBox感觉又怎么好,还不好控制,于是可以通过自定义控件的方式来解决,就又了下面的自定义ip控件,该控件功能基本完善,如果还有未 ...

  5. java 之 单例模式(大话设计模式)

    笔者记得去面试时曾被问起这个模式,当时还没有看过设计模式,对设计模式基本上一无所知,不过可以肯定的是笔者用过单例模式.当时回答的风马牛不相及,很尴尬. 也是从那时起,开始学习设计模式.今天所说的就是单 ...

  6. solr6.5.0版本(Windows安装图解)

    此教程为solr6.5.0安装,自己制作,希望可以帮到你们.

  7. 三十天学不会TCP,UDP/IP网络编程-IP头格式祥述

    我又来了,这篇文章还是来做(da)推(guang)介(gao)我自己的!俗话说事不过三,我觉得我下次得换个说法了,不然估计要被厌恶了,但是我是好心呐,一定要相信我纯洁的眼神.由于这两年接触到了比较多的 ...

  8. js函数的作用域与this指向

    函数的作用域与this指向是js中很重要的一部分,理清这点东西需要个逻辑,看看我的逻辑怎么样... 下面是个提纲,可以直接挑你感兴趣的条目阅读. 函数的定义方式:直接定义(window下,内部定义), ...

  9. Java基础—标识符及命名规范

      什么是标识符符? 凡是可以由自己命名的地方都称为修饰符. 例: 项目名 ,包名 ,类名 .方法名 2.   命名规范. ①    不可使用java关键字和保留字,但是可以包含关键字和保留字. ②  ...

  10. maven jetty struts异常 There is no Action mapped for namespace [/] and action name [] associated with context path

    毕业设计中用maven jetty插件调试时,struts出现这个错误,直接http://localhost:8080 无法进入默认主页,但换tomcat就没问题,最后在这篇文章找到答案 http:/ ...