设为首页 收藏本站
查看: 896|回复: 0

[经验分享] docker pipework

[复制链接]

尚未签到

发表于 2018-5-26 10:57:26 | 显示全部楼层 |阅读模式
  pipework 工作原理分析 :
DSC0000.jpg

  ·1.首先pipework检查是否存在 br0网桥,若不存在,就自己创建。
  ·2.创建veth pair 设备,用于为容器提供网卡并连接到br0网桥。
  ·3.使用docker inspect找到容器在主机中的PID,然后通过 PID将容器的网络命名空间链接到/var/run/netns/目录下。这么做的目的是,方便在主机上使用 ip netns命令配置容器的网络。
  因为,在Docker容器中,我们没有权限配置网络环境。
  ·将之前创建的veth pair 设备分别加入容器和网桥中。在容器中的名称默认为eth1,可以通过pipework的-i参数修改该名称。
  ·然后就是配置新网卡的 IP。若在 IP 地址的后面加上网关地址,那么 pipework 会重新配置默认路由。这样容器通往外网的流量会经由新配置的eth1出去,而不是通过eth0和docker0。
  (若想完全抛弃自带的网络设置,在启动容器的时候可以指定--net=none)
  以上就是 pipework 配置 Docker 网络的过程,这和 Docker 的 bridge 模式有着相似的步骤。
  事实上,Docker在实现上也采用了相同的底层机制。
  通过源代码,可以看出,pipework 通过封装Linux上的ip、brctl等命令,简化了在复杂场景
  下对容器连接的操作命令,为我们配置复杂的网络拓扑提供了一个强有力的工具。当然,如
  果想了解底层的操作,我们也可以直接使用这些 Linux命令来完成工作,甚至可以根据自己
  的需求,添加额外的功能
  pipework可以在下面用三个场景来使用和工作原理。
  1  将Docker 容器配置到本地网络环境中
  为了使本地网络中的机器和 Docker 容器更方便的通信,我们经常会有将 Docker 容器配置到和主机同一网段的需求。这个需求其实很容易实现,我们只要将 Docker 容器和主机的网卡桥接起来,再给Docker 容器配上IP就可以了。
  下面我们来操作一下:
  1.安装pipework
  wget https://github.com/jpetazzo/pipework.git
DSC0001.jpg

  2. 启动Docker容器
DSC0002.jpg

  3.-- 配置容器网络,并连到网桥 br0 上。网关在IP地址后面加@指定。
DSC0003.jpg

  4. 将主机eno16777736网卡桥接到 br0上,并把eno16777736 的 IP配置在br0上。
DSC0004.jpg

  注:如果是远程操作,中间网络会断掉,所以放在一条命令中执行。
DSC0005.jpg

  5.测试
DSC0006.jpg

  2  单主机Docker 容器 VLAN 划分
  pipework 不仅可以使用 Linux bridge 连接 Docker 容器,还可以与 OpenVswitch 结合,实现Docker 容器的 VLAN 划分。
  演示一下,在单机环境下,如何实现 Docker 容器间的二层隔离。
  1.安装openvswitch
  安装基础环境:yum install gcc make python-devel openssl-devel kernel-devel graphviz \ kernel-debug-devel autoconf automake rpm-build redhat-rpm-config libtool
  下载openvswitch的包:wget http://openvswitch.org/releases/openvswitch-2.3.1.tar.gz
  解压与打包
DSC0007.jpg

  复制
DSC0008.jpg

  修改
DSC0009.jpg

  下载
DSC00010.jpg

  查看一下
DSC00011.jpg

  安装并启动
DSC00012.jpg

  查看一下状态,有两个进程
DSC00013.jpg

  之后安装pipework
  创建交换机,把物理网卡加入ovs1
DSC00014.jpg

  或者
DSC00015.jpg

  创建4个docker容器
DSC00016.jpg

  划分vlan并加入
DSC00017.jpg

  加一条路由,就可以上网了
DSC00018.jpg

  最后相同vlan之间可以互相通信,可以使用外网。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-481283-1-1.html 上篇帖子: Docker镜像篇 下篇帖子: docker supervisor + compose
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表