这篇博客记录了自己实现OpenNF官网上tutorial的过程和遇见的问题,如果有不对的地方还请批评指正!

tutorial链接

实验内容

这个实验展示了如何迅速且安全地把一个TCP流从一个NF实例迁移到另一个NF实例。

实验环境

Ubuntu16.04(64位)

安装依赖

  • 安装OpenNF控制器、NF共享库和本次实验所需的依赖
sudo apt-get install git tcpreplay mininet ant oracle-java8-installer gcc make wget
  • 其中mininet最好使用源码安装,详情见mininet安装
  • oracle-java8-installer安装请参考oracle-java8-installer安装
  • 为了预防其他因素对本次实验的干扰,执行以下两条命令(如果需要使用网络,暂时先不要执行):
sudo service openvswitch-controller stop
sudo service network-manager stop
  • 手动安装json-c,详情见json-c安装
  • 本次实验我们用到了PRADS(一种网络功能,NF),安装它的依赖:
sudo apt-get install libpcre3-dev libpcap-dev python-docutils

安装SDN控制器和网络功能NF(network functions)

  • 创建一个名为tutorial的文件夹
mkdir tutorial
cd tutorial
wget https://github.com/floodlight/floodlight/archive/v0.90.tar.gz
tar xzvf v0.90.tar.gz
  • 克隆PRADS的源代码到tutorial目录下:
git clone https://github.com/gamelinux/prads.git
cd prads
git checkout 930ff5

下载OpenNF控制器代码

OpenNF要求,必须在注册之后才能下载他们的代码,给出注册链接。注册后,下载以下文件,并解压到tutorial目录下:

  1. NF控制器
  2. NF共享库
  3. 应用代码
  4. PRADS patch
  5. Mininet拓扑脚本

编译网络功能源码

  • 编译网络功能共享库:
cd tutorial/shared/
make
sudo make install
  • 执行这一步时,我遇见了以下错误:
SDMBNJson.h:9:23: fatal error: json/json.h: No such file or directory
#include <json/json.h>
^
compilation terminated.

解决方案

  • 编译PRADS:
cd tutorial/prads/
patch -p1 < ../prads.patch
make
sudo make install

编译OpenNF控制器

  • 为了让Floodlight控制器知道OpenNF控制器的存在,向Floodlight的model list文件(net.floodlightcontroller.core.module.IFloodlightModule)中添加如下几行,model list文件在tutorial/floodlight/src/main/resources/META-INF/services/目录下:
edu.wisc.cs.wisdom.sdmbn.core.SdmbnManager
edu.wisc.cs.wisdom.sdmbn.apps.testing.TestTimedMoveAll
  • 编译Floodlight:
cd tutorial/floodlight/
ant
  • 链接库:
cd tutorial/controller/lib/
ln -s ../../floodlight-0.90/target/floodlight.jar
  • 向OpenNF控制器的lib中加入GSON jar文件
  • 编译OpenNF控制器:
cd tutorial/controller/
ant
  • 编译应用:
cd tutorial/apps/
ant

配置实验

  • 修改OpenNF控制器配置文件中的一些参数,配置文件在tutorial/apps/testTimedMoveAll.prop:
net.floodlightcontroller.core.FloodlightProvider.openflowport = 6633
edu.wisc.cs.wisdom.sdmbn.core.SdmbnManager.stateport = 7790
edu.wisc.cs.wisdom.sdmbn.core.SdmbnManager.eventport = 7791
edu.wisc.cs.wisdom.sdmbn.apps.testing.TestTimedMoveAll.TraceReplaySwitchPort = 1
edu.wisc.cs.wisdom.sdmbn.apps.testing.TestTimedMoveAll.TraceReplayHost = 192.168.0.1
edu.wisc.cs.wisdom.sdmbn.apps.testing.TestTimedMoveAll.TraceReplayFile = youtube.pcap
  • 由于本次实验是通过重放tcp流来实现,所以我们要用tcpdump来抓包,注意抓包时要浏览网页,否则会造成抓包速度太慢:
cd tutorial/apps
tcpdump -i <本机的活动端口,比如eth0> -c 25000 -w youtube.pcap tcp
  • 修改NF共享库中的一些配置文件/usr/local/etc/sdmbn.conf:
ctrl_ip = 192.168.0.254

运行实验

  • 开启OpenNF控制器:
cd tutorial/apps/
java -jar SDMBNapps.jar -cf testTimedMoveAll.prop
  • 运行实验拓扑:
cd tutorial/
sudo python tutorial_topo.py
  • 开启三个主机的xterm:
mininet> xterm h1 h2 h3
  • 在h1的xtrem中执行:
cd tutorial/apps/
bash scripts/traceload_server.sh h1-eth0 . 192.168.0.1 8080
  • 在h2的xtrem中执行:
prads -i h2-eth0
  • 在h3的xtrem中执行:
prads -i h3-eth0

实验截图

OpenNF tutorial复现的更多相关文章

  1. Apache Druid 远程代码执行 CVE-2021-25646 漏洞复现

    Apache Druid 远程代码执行 CVE-2021-25646 漏洞复现 前言 Apache Druid 是用Java编写的面向列的开源分布式数据存储,旨在快速获取大量事件数据,并在数据之上提供 ...

  2. CVE-2021-25646:Apache Druid远程命令执行漏洞复现

    漏洞概述 Apache Druid 是一个分布式的数据处理系统.Apache Druid包括执行用户提供的JavaScript的功能嵌入在各种类型请求中的代码.在Druid 0.20.0及更低版本中, ...

  3. [翻译+山寨]Hangfire Highlighter Tutorial

    前言 Hangfire是一个开源且商业免费使用的工具函数库.可以让你非常容易地在ASP.NET应用(也可以不在ASP.NET应用)中执行多种类型的后台任务,而无需自行定制开发和管理基于Windows ...

  4. Django 1.7 Tutorial 学习笔记

    官方教程在这里 : Here 写在前面的废话:)) 以前学习新东西,第一想到的是找本入门教程,按照书上做一遍.现在看了各种网上的入门教程后,我觉得还是看官方Tutorial靠谱.书的弊端一说一大推 本 ...

  5. thrift 服务端linux C ++ 与客户端 windows python 环境配置(thrift 自带tutorial为例)

    关于Thrift文档化的确是做的不好.摸索了很久才终于把跨linux与windows跨C++与python语言的配置成功完成.以下是步骤: 1)                 Linux下环境配置 ...

  6. Hive Tutorial(上)(Hive 入门指导)

    用户指导 Hive 指导 Hive指导 概念 Hive是什么 Hive不是什么 获得和开始 数据单元 类型系统 内置操作符和方法 语言性能 用法和例子(在<下>里面) 概念 Hive是什么 ...

  7. Home / Python MySQL Tutorial / Calling MySQL Stored Procedures in Python Calling MySQL Stored Procedures in Python

    f you are not familiar with MySQL stored procedures or want to review it as a refresher, you can fol ...

  8. Using FreeMarker templates (FTL)- Tutorial

    Lars Vogel, (c) 2012, 2016 vogella GmbHVersion 1.4,06.10.2016 Table of Contents 1. Introduction to F ...

  9. Oracle Forms 10g Tutorial Ebook Download - Oracle Forms Blog

    A step by step tutorial for Oracle Forms 10g development. This guide is helpful for freshers in Orac ...

随机推荐

  1. web前端 pdf 版电子 好书籍

    http://www1.w3cfuns.com/feres.php?do=picture&listtype=book

  2. 基于 HTML5 Canvas 的 Web SCADA 组态电机控制面板

    前言 HT For Web 提供完整的基于 HTML5 图形界面组件库.您可以轻松构建现代化的,跨桌面和移动终端的企业应用,无需担忧跨平台兼容性,及触屏手势交互等棘手问题.也可用于快速创建和部署,高度 ...

  3. Hadoop源码学习笔记之NameNode启动场景流程五:磁盘空间检查及安全模式检查

    本篇内容关注NameNode启动之前,active状态和standby状态的一些后台服务及准备工作,即源码里的CommonServices.主要包括磁盘空间检查. 可用资源检查.安全模式等.依然分为三 ...

  4. parted 命令学习

    背景:fdisk命令是针对MBR分区进行操作,MBR分区因为自身设计原因,不能处理大于2TB的硬盘,并且只能有4个分区.针对大于2TB的硬盘,需要采用GPT分区,使用parted命令进行操作 part ...

  5. (三)SpringBoot2.0基础篇- 持久层,jdbcTemplate和JpaRespository

    一.介绍 SpringBoot框架为使用SQL数据库提供了广泛的支持,从使用JdbcTemplate的直接JDBC访问到完整的“对象关系映射”技术(如Hibernate).Spring-data-jp ...

  6. cogs2109 [NOIP2015] 运输计划

    cogs2109 [NOIP2015] 运输计划 二分答案+树上差分. STO链剖巨佬们我不会(太虚伪了吧 首先二分一个答案,下界为0,上界为max{路径长度}. 然后判断一个答案是否可行,这里用到树 ...

  7. Windows 实例搭建的 FTP 在外网无法连接和访问

    外网无法连接和访问 Windows 实例搭建的 FTP,这种情况可能是由于以下两种原因导致的: 安全组拦截外网访问 防火墙拦截 FTP 进程 安全组拦截外网访问 这种情况下,可以尝试新建一条入方向的安 ...

  8. WPF获取窗口句柄

    通过WPF的互操作帮助类WindowInteropHelper,相关连接:https://msdn.microsoft.com/zh-cn/library/system.windows.interop ...

  9. Qt-QML-Canvas-雷达扫描仪表简单

    使用QML实现的雷达仪表的实现,主要实现了余晖扫描的实现,其他的还是比较简单的,后面可能会加入目标标识,目前的功能仅仅是一个假的扫描雷达 来看代码 /* 作者:张建伟 时间:2018年4月27日 简述 ...

  10. 理解学习Springboot(二)

    一.关闭banner 如果不想看到任何的banner,可以将其关闭. 当然也可以自己自定义banner,http://patorjk.com/software/taag/#p=display& ...