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

[经验分享] Openstack网络流程分析

  [复制链接]

尚未签到

发表于 2017-6-27 14:59:42 | 显示全部楼层 |阅读模式
  创建好云主机之后,直接就可以ping通外网,但它的流程是怎样的呢?
  还是之前的三节点架构,云主机上网这里只和计算节点还有网络节点有关
那就先从计算节点开始说吧
DSC0000.png

  上边的就是我自己画的计算节点的网络图一步步来分析
  先看计算节点都有什么网卡
DSC0001.png

  一共10(没有10号,直接11号)个:
  1.lo,本地网卡这个没什么好说的
  2.eno16777736,这个是计算节点的管理网络网卡,平时操作节点就通过这个网卡连过去
  3.eno33554984,这个是计算节点的数据网络,隧道建立就是通过这块网卡
  4.ovs-system,这个是openvswitch系统的网卡
  5.br-tun,这个就是上图中的br-tun,是一个ovs设备,相当于一个交换机,启用openflow
  6.br-int,这个就是上图中的br-int,也是个ovs设备,交换机,但没有启用openflow
  7.qbr3a273dcc-6e,这个是Linux网桥,每个vm对应一个Linux网桥,用来设置安全组
  8.qvo3a273dcc-6e@qvb3a273dcc-6e,这个就是ovs连接Linux网桥的端口,因此它的master是ovs-system
  9. qvb3a273dcc-6e@qvo3a273dcc-6e,这个是Linux网桥连接ovs的端口,因此它的master是qbr3a273dcc-6e
  11.tap3a273dcc-6e,这个就是一个tap设备,vm连接Linux网桥用的
  接下来看看ovs交换机的信息
DSC0002.png

  一共是两个交换机br-int和br-tun
  先看br-int:
  1.qvo3a273dcc-6e,这个端口用来连Linux网桥,它的tag是1也就是VLAN1,说明连在这个网桥中的vm是属于VLAN1的,接口也是同名的(一般情况下port和interface都是一对一的关系,除非在配置 Port 为 bond 模式后,Port 和 Interface 是一对多的关系)
  2.br-int,这个就是自己喽
  3.patch-tun,这个是用来连br-tun的,类型是patch,options说明它也patch-int是一对patch对
  4.这个和第一个是一样的,因为我有两个vm
  接下来是br-tun:
  1.patch-int,这个就是用来连br-int的,类型也是patch,options说明它和上边那个br-int里的patch-tun是一对patch对
  2.vxlan-0101010d,这个是vxlan的端口,类型是vxlan,options里的in-key和out-key都是flow(就是用openflow),local_ip是计算节点的数据网络,remote_ip是网络节点的数据网络,就是这两个网卡在建立隧道的
  3.gre-0101010d,这个是gre的端口,除了类型是gre之外,其他都和vxlan端口一样
  4.br-tun,这个就是自己喽
  这就是计算节点的网络了
看看网络节点的网络
DSC0003.png

  同样先看看它都有哪些网卡
DSC0004.png

  一共七个:
  1.lo,网络节点的本地网卡
  2.eno16777736,这个是用来做管理网络和外部网络的网卡,因为我把它添加到br-ex交换机上了,所以它没有配置ip,而是被br-ex配置了ip
  3.eno33554984,这个是用来做数据网络的,也就是用来建立隧道的,跟计算节点一样
  4.ovs-system,也跟计算节点一样,ovs必备的网卡
  5.br-ex,用来让vm连接都外网的网卡,同时也是我的网络节点管理网络
  6.br-tun,跟计算节点一样用来连接br-int和网络节点
  7.br-int,这个是用来连接br-tun和dhcp设备还有router设备
  然后看看ovs交换接信息
DSC0005.png DSC0006.png

  这个就要比计算节点多出一个br-ex了,因为vm对互联网的数据包就是通过它发出去的
  先看br-tun:
  1.vxlan-0101010c,这个就是隧道的另一端了,可见这里的local_ip就是计算节点上的remote_ip,remote_ip就是计算节点的local_ip
  2.patch-int,与br-int上patch-tun对应的patch对
  3.gre-0101010c,gre端口
  4.br-tun,自己
  接下来是br-int:
  1.tapa0371d65-38,就是连接external网络中dhcp设备的端口
DSC0007.png

  2.br-int,自己
  3.tapb0606cb8-fa,用来连接demo网络中的dhcp设备
DSC0008.png

  4.int-br-ex,一个连接到br-ex的patch端口,但具体也没什么用
  5.patch-tun,与br-tun上的patch-int对应
  6.qr-239358f7-b8,上图demo网络中的路由器就连在这里
  最后是br-ex了:
  1.qg-5f1c5b76-8f,就是路由器的另一个接口
  2.eno16777736,添加的可以访问外网的网卡
  3.phy-br-ex,与int-br-ex对应,没用
  4.br-ex,自己
  以上就是所有的交换机以及端口。
  接下来是vm访问百度的数据包走过的路
  先是通过tap设备发到Linux网桥,然后再发到计算节点的br-int,br-int为其打上vlan_id通过patch对发到br-tun,br-tun去掉vlan_id打上tunnel_id,通过隧道发到网络节点的br-tun,网络节点的br-tun去掉tunnel_id,打上对应的vlan_id,通过patch对发给网络节点的br-int,br-int再通过tap设备发给router,router经过转换ip发给br-ex,最终由br-ex的eno16777736端口发出去。

运维网声明 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-388744-1-1.html 上篇帖子: openstack-glance API 镜像管理的部分实现和样例 下篇帖子: 大陆地区OpenStack项目Core现状(截至2016年1月28日,转载自陈沙克日志)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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