OpenDaylight Hydrogen版本应用SampleTap研究(一)

最近在网上看到了一个以OpenDaylight为基础的SDN应用,所以下载下来研究了一番,简单的对其相关功能进行了研究,由于精力有限,只完成了代码编译和OpenDaylight对接工作,并未对其业务流程进行深入研究,先将几天的研究进展小结一下,后续将对代码进行深入研究,如果有精力准备将其移植到OpenDaylight的最新版本上。

1 什么是Tap

    Tap在wiki中的解释中是一种提供通过计算机网络去接入数据流的方式。在实际应用中,Tap是效果较好的一种监控网络节点间流量的方式。满足Tap应用场景的网络一般会具备三个重要部分,即需要监控的两个节点AB,还有监控节点(monitor port)。在AB间插入Tap后,Tap在保证未阻塞的流量通过的同时会将流量拷贝到监控端口供第三方的设备监听。

应用场景:breakoutpassiveaggregatingregenerationinline power

2 SampleTap实现

    SampleTap使用Java进行开发,其实际是作为OpenDaylight Hydrogen版本的软件架构OSGiPlugin存在的。其代码分为两个部分,一个部分是SampleTap的功能实现,另一部分是SampleTapOSGi的接口实现,代码存在于internal文件中,对OSGibundle进行了实现。其与OpenDaylight的关系如图2-1所示.

OpenDaylight Hydrogen版本应用SampleTap研究(一)_第1张图片

2-1 SampleTapOpenDaylight的关系

    SampleTap的功能实现本质其实是通过下发流表进行特定流量的备份,并通过相应的功能模块进行流量分析,以满足不同的需求。

在整个SampleTap应用中,核心的内容是Tap Policy,其制定了Tap的应用策略,实现思路是通过NameMatch RulesSwitches/Ports确定流量,然后将流量镜像转移至相应的Capture Device进行数据包处理。图2-2上半部分是整个Policy的主要数据结构,下半部分是Match Rules的相关数据结构,这里相较于OFMatch Rules多了个Refexive的功能,也就是说可以选择是否增加反向链路的匹配功能。

OpenDaylight Hydrogen版本应用SampleTap研究(一)_第2张图片

2-2 SampleTap的策略结构

3 SampleTap实验分析

    对于SampleTap的实验,官方举了两个例子,下面分别介绍一下。

OpenDaylight Hydrogen版本应用SampleTap研究(一)_第3张图片

3-1 案例一——Tap聚合

    在这个例子中,将TOR交换机的镜像端口都连接在了安装了Tap应用的交换机,该交换机有两类端口,一种是Recorder用来实现流量的记录,而inspector主要实现对流量的监测。根据图3-1可以看出Tap应用聚合了图中左上多台交换机的流量,并进行了相应的监测。

OpenDaylight Hydrogen版本应用SampleTap研究(一)_第4张图片

根据图3-2,该例子其实是对案例一的详细化,主要完成ClientServer之间特定流量的分析,Client1Server1的交换机设定为TOR交换机,其和运行Tap应用的交换机之间通过Tap Port进行连接,该端口可以理解为交换机的镜像端口。该案例的目的是将CleintServer间的流量进行镜像备份,并从中筛选出HTTPFTP的数据包给Inspect端口进行分析。

本文未完,阅读原文请点击:http://www.sdnlab.com/11894.html


你可能感兴趣的:(OpenDaylight Hydrogen版本应用SampleTap研究(一))