这篇博客记录了自己实现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. MongoDB的高级使用

    MongoDB的高级使用 1. Mongdb的索引备份以及和python交互 t255为mongodb中的集合 1.1 创建索引 索引的特点:提高查找的效率 不创建索引的情况下的查询: for(i=0 ...

  2. 树莓派3B+学习笔记:9、更改软件源

    树莓派系统安装完成后,由于默认软件源服务器访问速度慢,安装软件耗时会很长,可以通过更改软件源来加快软件的安装速度. 系统安装完成后默认软件源如下: 更改镜像源前需要自行查找镜像源,并记下网址: 1.阿 ...

  3. 从零开始的Python学习Episode 15——正则表达式

    正则表达式 正则表达式(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中,并通过 re 模块实现,所以使用时要导入re模块.正则表达式模式被编译成一系列的字节码 ...

  4. 20155210潘滢昊 2016-2017-2 《Java程序设计》第2周学习总结

    20155210潘滢昊 2016-2017-2 <Java程序设计>第2周学习总结 教材学习内容总结 %%:表示字符串中的%. %d:以十进制整数格式输出 %f:以十进制浮点式格式输出 % ...

  5. 20155313 实验二《Java面向对象程序设计》实验报告

    20155313 实验二<Java面向对象程序设计>实验报告 一.实验内容 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 4. ...

  6. 20155331 2016-2017-2 《Java程序设计》第九周学习总结

    20155331 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 JDBC是什么? JDBC代表Java数据库连接,这对Java编程语言和广泛的数据库之间独立 ...

  7. 20155336 《Java程序设计》实验二 (Java面向对象程序设计)实验报告

    20155336 <Java程序设计>实验二 (Java面向对象程序设计)实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉 ...

  8. 【excle基础】如何去掉excel某一列中的字段的空格

    如图所示,想要去掉A列的空格: 查找空格,全部替换

  9. C# 合并多个结构相同的DataTable

    public DataTable GetAllDataTable(DataSet ds) { DataTable newDataTable = ds.Tables[0].Clone(); //创建新表 ...

  10. Scrapy爬去哪儿~上海一日游门票并存入MongoDB数据库

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZwAAAGGCAYAAABPDDfEAAAgAElEQVR4nOy9C3Rb1Z3/+z1Hkm35mT