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

[经验分享] Dockernet Open vSwitch

[复制链接]

尚未签到

发表于 2019-1-26 14:01:15 | 显示全部楼层 |阅读模式

  创建topo

user@user-VirtualBox:~$ sudo mn --topo single,2        
  基本操作:

dockernet>sh ovs-ofctl dump-flows s1 -->(显示规则)      
dockernet>sh ovs-ofctl del-flows s1 -->(删除规则)      
dockernet>sh ovs-ofctl add-flow s1 -->(新增规则)      
  注意


  • idle-timeout 这个规则没有符合这个封包经过,这个规则被闲置多久后就会被删除(sec)
  • hard-timeout 不管有没有封包经过,只要设置的时间一到,就直接删除规则(sec)
  • priority 权值,这个规则排行是排多少,最小是1,最高是65535
  • dl_src  (dl = data link层)  这个表示 来源端的网路卡卡号
  • dl_dst  这个表示 目的端的网路卡卡号
  • dl_type 这个表示 种类(0x0800 =IP  0x0806 =ARP)
  • ip_proto =1 icmp   (设规则时简化成inport= 1 )
  • ip_proto =6 tcp
  • ip_proto =17 udp

实验一:
  我们现在练习手动设定规则:
首先,我们在创建topo时,因为有一个controller,他会自动内定规则,使得h1、h2能够互相沟通。
这时,我们必须要先将contorller干掉,手动写入规则(删除规则后h1、h2便无法通讯了)

user@user-VirtualBox:~$ sudo ps -ef | grep controller
user@user-VirtualBox:~$ sudo kill -9 (这边写contorller的进程号)


dockernet>sh ovs-ofctl add-flow s1 in_port=1,actions=output:2
  当我们新增完后,
我们可以另外开一个terminal然后输入下列指令查看当前s1的规则

user@user-VirtualBox:~$ sudo ovs-ofctl show s1

在上图中,会看到:



  • dpid = data path id (这是每一台交换机的识别码,在虚拟环境中以最简单的方式呈现)
  • n_buffers 缓冲区的大小
  • actions 支援的动作  enqueue(主要在做QoS)我们把封包的丢初去时,可以先把封包丢到事先设定好的不同伫列,并针对不同的伫列去设定不同的频宽(一个output可以支援8个queues q0=default queue ,数值越高的优先权越高)
  • set_vlan_vid 要设定vlan时要帮封包打标签
  同理,在新增回覆的规则

dockernet>sh ovs-ofctl add-flow s1 in_port=2,actions=output:1
dockernet>xterm h1 h2
进到h1 h2
arp -n --->(查看目前有的arp)
arp -d 10.0.0.2(这里要看目前有哪一个arp的纪录,就删除哪一个,这样才方便下面做通讯的观察)
在h2:
tcpdump -i h2-eht0
在h1:
ping -c 3 10.0.0.2


从上图h2监听的过程会发现,ARP Request,ARP reply,三组ICMP(去回)的封包(因为ping -c 3),加上后面持续的ARP Request以及ARP reply,总共10个封包。

  我们开启另外一个terminal来看:

其中,两个规则的n_packets皆等于5,所以刚好可以匹配上面监听的传送10个封包(双向传输,每一个方向各五个)
  特别注意:在每一次实验完后,都要执行sudo mn-c 将上一个实验的规则完全清除干净,避免下面产生问题

实验二

user@user-VirtualBox:~$ sudo mn --topo single,2 --mac
dockernet> sh ovs-ofctl add-flow s1 priority=1,in_port=1,action=output:2
dockernet> sh ovs-ofctl add-flow s1 priority=2,in_port=1,action=output:1
dockernet> sh ovs-ofctl dump-flows s1


dockernet> sh ovs-ofctl add-flow s1 priority=10,ip,nw_dst=10.0.0.1,actions=output:1
dockernet>sh ovs-ofctl add-flow s1 priority=10,dl_type=0x0800,nw_dst=10.0.0.2,actions=output:2    (dl_type=0x0800  等于 ip )

dockernet>xterm h1 h2
进到h1 h2
arp -n --->(查看目前有的arp)
arp -d 10.0.0.2(这里要看目前有哪一个arp的纪录,就删除哪一个,这样才方便下面做通讯的观察)
在h2:
tcpdump -i h2-eht0
在h1:
ping -c 3 10.0.0.2







运维网声明 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-667868-1-1.html 上篇帖子: ESX Cannot open the disk ‘XXXXXX.vmdk’.... 下篇帖子: Open Relay 测试链接
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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