【Mininet】基础篇:开源控制器POX

这篇具有很好参考价值的文章主要介绍了【Mininet】基础篇:开源控制器POX。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

大家好,我是文思月!

每文一言:时间不在于你拥有多少,而在于你如何使用!

本篇文章:

本篇文章主要是基于POX控制器进行的两个实验:一个是使交换机模拟hub(集线器)的功能,一个是让交换机实现L2自学习。POX是一个SDN控制器,编程语言是python。

在开始之前,首先需要在ubuntu中安装POX,安装POX参考如下教程:

https://blog.csdn.net/langzi_a/article/details/104730264

正文如下:

实验一:交换机模拟hub的功能

第一步:启动POX,运行hub.py文件

./pox.py log.level --DEBUG forwarding.hub

第二步:使用Mininet创建如下网络拓扑,OpenFlow协议为1.0,控制器使用本地部署的POX(默认监听6633端口):

【Mininet】基础篇:开源控制器POX

sudo -E mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow10

第三步:在Mininet命令行模式下打开h2,h3主机终端

xterm h2 h3

第四步:在h2主机终端输入:

tcpdump -nn -i h2-eth0

第五步:在h3主机终端输入:

tcpdump -nn -i h3-eth0

【Mininet】基础篇:开源控制器POX

第六步:在Mininet命令行输入:

h1 ping h2

h2和h3可以同时收到数据包

【Mininet】基础篇:开源控制器POX

第七步:在Mininet命令行输入:

h1 ping h3

h2和h3可以同时收到数据包

【Mininet】基础篇:开源控制器POX

运行hub.py使得创建的交换机上都安装了泛洪规则,交换机收到数据包后,会将数据包进行泛洪,此时交换机相当于是集线器。所以,在ping某个主机的时候,其他主机也会收到数据包。

实验二:L2学习交换机的功能

1)使用源地址和交换机端口去更新地址/端口表

2)包的transparent=false,并且以太网类型是LLDP,或者包的目的地址是一个网桥过滤地址的时候?

  • 2a)yes:丢弃这个包,不要转发这个当前链路上的数据流

3)包的目的地址是否是多播地址?

  • 3a)yes:泛洪这个包

4)数据包的目的地址是否在我们的地址/端口表中?

  • 4a)No:泛洪这个包

5)包的输出端口是否和输入端口相同?

  • 5a)yes:丢弃这个包和之后相似的数据包

6)在交换机中安装流表项,使得这些数据流可以从相应的端口出去

  • 6a)发送数据包到相应的端口

L2_learning.py代码的程序流程图:

【Mininet】基础篇:开源控制器POX

第一步:启动POX,运行l2_learning.py文件

./pox.py log.level --DEBUG forwarding.l2_learning

第二步:使用Mininet创建如下网络拓扑,OpenFlow协议为1.0,控制器使用本地部署的POX(默认监听6633端口):

【Mininet】基础篇:开源控制器POX

sudo -E mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow10

第三步:在Mininet命令行模式下打开h2,h3主机终端

xterm h2 h3

第四步:在h2主机终端输入:

tcpdump -nn -i h2-eth0

第五步:在h3主机终端输入:

tcpdump -nn -i h3-eth0

【Mininet】基础篇:开源控制器POX

第六步:在Mininet命令行输入:

h1 ping h2

【Mininet】基础篇:开源控制器POX

h2主机收到数据包,h3主机没有收到数据包

第七步:在Mininet命令行输入:

h1 ping h3

【Mininet】基础篇:开源控制器POX

h3主机收到数据包,h2主机没有收到数据包

交换机实现了L2_learning,只有目的主机可以收到数据包。

实验三:python程序自定义POX控制器功能

新建网络拓扑,此时交换机没有流表规则,该拓扑上的主机不能进行通信;编写python程序自定义一个POX模块SendFlowlnSingle3,并将拓扑连接到SendFlowlnSingle3(默认端口为6633),实现交换机发送流表规则,完成主机的通信。

第一步:建立网络拓扑

sudo -E mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow10

第二步:测试主机之间能否进行通信

h1 ping h2

【Mininet】基础篇:开源控制器POX

主机之间无法进行通信

第三步:在pox文件夹下新建SendFlowlnSingle3.py文件,并加入如下代码

# -*- coding: utf-8 -*-
from pox.core import core
import pox.openflow.libopenflow_01 as of

class SendFlowInSingle3(object):
    def __init__(self):
        core.openflow.addListeners(self)
    def _handle_ConnectionUp(self, event):
        msg = of.ofp_flow_mod()  # 使用ofp_flow_mod()方法向交换机下发流表
        msg.priority = 1
        msg.match.in_port = 1  # 使数据包进入端口1
        msg.actions.append(of.ofp_action_output(port=2))  # 从端口2转发出去
        msg.actions.append(of.ofp_action_output(port=3))  # 从端口3转发出去
        event.connection.send(msg)

        msg = of.ofp_flow_mod()  # 使用ofp_flow_mod()方法向交换机下发流表
        msg.priority = 1
        msg.match.in_port = 2  # 使数据包进入端口2
        msg.actions.append(of.ofp_action_output(port=1))  # 从端口1转发出去
        msg.actions.append(of.ofp_action_output(port=3))  # 从端口3转发出去
        event.connection.send(msg)

        msg = of.ofp_flow_mod()  # 使用ofp_flow_mod()方法向交换机下发流表
        msg.priority = 1
        msg.match.in_port = 3  # 使数据包进入端口3
        msg.actions.append(of.ofp_action_output(port=1))  # 从端口1转发出去
        msg.actions.append(of.ofp_action_output(port=2))  # 从端口2转发出去
        event.connection.send(msg)

def launch():
    core.registerNew(SendFlowInSingle3)

第四步:运行该文件:

sudo ./pox.py SendFlowInSingle3

第五步:测试主机之间能否进行通信:

h2 ping h3

【Mininet】基础篇:开源控制器POX

主机之间可以进行相互通信


本篇文章主要介绍了POX相关的使用,后续会继续更新Mininet相关使用。


参考博客:
https://www.cnblogs.com/islinbei/p/16770062.html文章来源地址https://www.toymoban.com/news/detail-475267.html

到了这里,关于【Mininet】基础篇:开源控制器POX的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 飞天使-k8s基础组件分析-控制器

    控制器含义解释 pod的标签与注释 ReplicaController ReplicaSet Deployments DaemonSet Job Cronjob 参考文档

    2024年02月11日
    浏览(48)
  • 生动的SDN基础内容介绍(三)--Ryu控制器

    之前介绍完了南向协议OpenFlow,这次说一说Ryu。因为毕设的时候师兄推荐了Ryu,再考虑到Python方便开发,我也就继续用Ryu了。但是后续发现好像支持Ryu开发的框架相较Floodlight、OpenDaylight、ONOS没那么多(但也可能只是我没找到)。 首先非常强烈推荐这位大哥的博客: https://w

    2023年04月15日
    浏览(48)
  • 【Three.js基础】创建场景、渲染场景、创建轨道控制器(一)

    🐱 个人主页: 不叫猫先生 🙋‍♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀! 💫系列专栏:vue3从入门到精通、TypeScript从入门到实践 📢 资料领取:前端进阶资料以及文中源码可以找我免费领取 🔥 前端

    2024年02月01日
    浏览(64)
  • CAN总线基础详解以及stm32的CAN控制器

    目录 CAN简介 CAN总线拓扑图 CAN总线特定 CAN应用场景 CAN的物理层 CAN的协议层 CAN数据帧介绍 CAN位时序介绍 数据同步过程 硬件同步 再同步 CAN总线仲裁 stm32的CAN控制器 CAN控制器介绍 CAN控制器模式 CAN控制器框图 接收过滤器 CAN控制器波特率计算 CAN相关寄存器 CAN主控制寄存器(

    2024年01月25日
    浏览(49)
  • Three.js基础入门介绍——Three.js学习三【借助控制器操作相机】

    在Three.js基础入门介绍——Three.js学习二【极简入门】中介绍了如何搭建Three.js开发环境并实现一个包含旋转立方体的场景示例,以此为前提,本篇将引进一个控制器的概念并使用”轨道控制器”(OrbitControls)来达到从不同方向展示场景内容的效果。 Three.js的控制器 three.js的核

    2024年02月04日
    浏览(66)
  • 【Unity游戏开发教程】零基础带你从小白到超神16——四种方法控制人物移动之角色控制器

    直接修改组件位置 去资源商城下载角色控制系统成品直接拿来用 unity提供的角色控制器组件 通过物理系统自己做

    2024年02月08日
    浏览(47)
  • 控制器局域网(CAN)物理层调试的基础知识和实例分析

    控制器局域网的概念 控制器局域网是国际上应用最广泛的现场总线之一。CAN被设计作为汽车环境中的微控制器通讯,在车载各电子控制装置ECU之间交换信息,形成汽车电子控制网络。比如:发动机管理系统、变速箱控制器、仪表装备、电子主干系统中,均嵌入CAN控制装置。

    2024年02月07日
    浏览(53)
  • 第21章_瑞萨MCU零基础入门系列教程之事件链接控制器ELC

    本教程基于韦东山百问网出的 DShanMCU-RA6M5开发板 进行编写,需要的同学可以在这里获取: https://item.taobao.com/item.htm?id=728461040949 配套资料获取:https://renesas-docs.100ask.net 瑞萨MCU零基础入门系列教程汇总 : https://blog.csdn.net/qq_35181236/article/details/132779862 本章目标 了解ELC基本概念

    2024年02月08日
    浏览(42)
  • k8s基础4——deployment控制器、应用部署、升级、回滚、水平扩容缩容

    基本了解: Deployment是最常用的K8s工作负载控制器(Workload Controllers),实际项目部署调试中必用资源之一,所以必须要熟练掌握deploy资源的使用。 它是K8s的一个抽象概念,用于更高级层次对象,部署和管理Pod。 其他控制器还有DaemonSet、StatefulSet等,不同控制器针对不同的需

    2024年02月03日
    浏览(56)
  • K8s基础10——数据卷、PV和PVC、StorageClass动态补给、StatefulSet控制器

    为什么需要数据卷? 容器中的文件在磁盘上是临时存放的,这给容器中运行比较重要的应用程序带来一些问题。 当容器升级或者崩溃时,kubelet会重建容器,容器内文件会丢失。 一个Pod中运行多个容器时,需要共享文件。 而K8s 数据卷就可以解决这两个问题。 Volume概念: V

    2024年02月05日
    浏览(99)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包