1.使用Vmware打开下载好的mininet-2.2.2-170321-ubuntu-14.04.4-server-amd64

2.登录账号密码都为mininet

3.用命令行生成拓扑,并测试连通性

1)最小的网络拓扑,一个交换机下面挂两个主机:sudo mn --topo minimal,exit退出

{ps:.每次要新建拓扑时,需执行以下命令,防止上次操作对本次实验的影响

sudo mn -c (以下步骤新建拓扑时也要执行此命令)}

2)每个交换机连接一个主机,交换机间相连接。本例:4个主机,4个交换机。

sudo mn --topo linear,4

3)每个主机都连接到同一个交换机上。本例:3个主机,一个交换机。

sudo mn --topo single,3

4)定义深度和扇出形成基于树的拓扑。本例:深度2,扇出2。

sudo mn --topo tree, fanout=2,depth=2

4.Python脚本定义拓扑

【1】--topo linear,4。

1)新建linear.py 文件:touch linear.py

2)编辑文件:vim linear.py,添加一下内容:

from mininet.net import Mininet

from mininet.topo import LinearTopo

Linear4 = LinearTopo(k=4)    #四个交换机,分别下挂一个主机

net = Mininet(topo=Linear4)

net.start()

net.pingAll()

net.stop()

3)修改文件linear.py为可执行文件:chmod +x linear.py

4)运行脚本:sudo python linear.py
【此时如果报错:a.文件内容错误,检查后对应修改后重新运行脚本即可
                             b.出现所示错误:Exception:Error creating interface pair(s2-eth2,s1-eth2);RTNETLINK answers:file exist

则运行sudo mn -c命令后重新运行脚本】

5)成功的样子:

【2】--topo single,3。

详见【1】,步骤相同,仅脚本内容不同

from mininet.net import Mininet

from mininet.topo import SingleSwitchTopo

Single3 = SingleSwitchTopo(k=3)   #一个交换机下挂3个主机

net = Mininet(topo=Single3)

net.start()

net.pingAll()

net.stop()

【3】--topo tree,depth=2,fanout=2。同上

from mininet.net import Mininet

from mininet.topolib import TreeTopo

Tree22 = TreeTopo(depth=2,fanout=2)

net = Mininet(topo=Tree22)

net.start()

net.pingAll()

net.stop()

【4】适合各种拓扑形式的脚本创建模式。本例:1个交换机,2个主机,并且赋予主机IP地址。

from mininet.net import Mininet

net = Mininet()

# Creating nodes in the network.

c0 = net.addController()

h0 = net.addHost('h0')

s0 = net.addSwitch('s0')

h1 = net.addHost('h1')

# Creating links between nodes in network

net.addLink(h0, s0)

net.addLink(h1, s0)

# Configuration of IP addresses in interfaces

h0.setIP('192.168.1.1', 24)

h1.setIP('192.168.1.2', 24)

net.start()

net.pingAll()

net.stop()

【5】在此基础上对性能进行限制。(addHost()语法可以对主机cpu进行设置,以百分数的形式;addLink()语法可以设置带宽bw、延迟delay、最大队列的大小max_queue_size、损耗率loss。)

from mininet.net import Mininet

from mininet.node import CPULimitedHost

from mininet.link import TCLink

net = Mininet(host=CPULimitedHost, link=TCLink)

c0 = net.addController()

s0 = net.addSwitch('s0')

h0 = net.addHost('h0')

h1 = net.addHost('h1', cpu=0.5)

h2 = net.addHost('h1', cpu=0.5)

net.addLink(s0, h0, bw=10, delay='5ms',

max_queue_size=1000, loss=10, use_htb=True)

net.addLink(s0, h1)

net.addLink(s0, h2)

net.start()

net.pingAll()

net.stop()

5.交互式界面创建主机、交换机等

1)$sudo mn

2)添加主机h3:

3)添加link:

4)给交换机s1添加端口eth3用于连接h3:

5)给h3赋予IP(10.0.0.3)以及h1 ping h3

6.测试网络

1)展示所有的网络信息。

2)所有节点的ping测试。

{ 如果出现以下错误:

***Ping:testing ping reachability
h1->h2 ***Error:could not parse ping output:ping:unknown host None
h2->h1 ***Error:could not parse ping output:ping:unknown host None

则输入命令s1 ping h3后,重新执行py net.pingAll()

附:

1.实验环境:

打开虚拟机镜像( SDNHub_tutorial_VM_64-bit[NEW](可直接导入 VMware).ova ), 下载链接:https://pan.baidu.com/s/1qYN_MtUboPmruHda1DgrTA 提取码:mhfi

注:也可以在也可以安装其他虚拟机软件,如 VirtualBox、KVM 等,然后安装 mininet, 安装方法见 http://mininet.org/download/

2.mininet背景:

Mininet 是由一些虚拟的终端节点(end-hosts)、交换机、路由器连接而成的一个网络仿真器,是一个轻量级软件定义网络和测试平台;它采用轻量级的虚拟化技术使一个单一的系统看起来像一个完整的网络运行想过的内核系统和用户代码,也可简单理解为 SDN 网络系统中的一种基于进程虚拟化平台,它支持 OpenFlow、OpenvSwith  等各种协议,Mininet  也可以模拟一个完整的网络主机、链接和交换机在同一台计算机上且有助于互动开发、测试和演示,尤其是那些使用 OpenFlow 和 SDN 技术;同时也可将此进程虚拟化的平台下代码迁移到真实的环境中。

Mininet 可以很方便地创建一个支持 SDN 的网络:host 就像真实的电脑一样工作,可以使用 ssh 登录,启动应用程序,程序可以向以太网端口发送数据包,数据包会被交换机、路由器接收并处理。有了这个网络,就可以灵活地为网络添加新的功能并进行相关测试,然后轻松部署到真实的硬件环境中。

3.mininet特性:

1) 可以简单、迅速地创建一个支持用户自定义的网络拓扑,缩短开发测试周期

2) 可以运行真实的程序,在 Linux 上运行的程序基本上可以都可以在 Mininet 上运行,如 Wireshark

3) Mininet 支持 Openflow ,在 Mininet 上运行的代码可以轻松移植到支持OpenFlow 的硬件设备上

4) Mininet 可以在自己的电脑,或服务器,或虚拟机,或者云(例如 Amazon EC2) 上运行

5) Mininet 提供 python API,简单易用

6) Mininet 是开源项目

4.部分命令:

 

mininet > help

 

获取帮助列表。

 

mininet > nodes

 

查看 mininet 中结点的状态。

 

mininet >net

 

显示网络拓扑

 

mininet >dump

显示每个节点的接口设置和表示每个节

点的进程的 PID

 

mininet > pingall

在网络中的所有主机之间执行 ping 测试

 

mininet > h1 ping h2

h1 和 h2 节点之间执行 ping 测试

 

mininet > h1 ifconfig

查看 host1 的 IP 等信息。

 

mininet > xterm h1

 

打开 host 1 的终端。

 

mininet > exit

退出 mininet 登录。

mininet-2.2.2-170321-ubuntu-14.04.4-server-amd64的使用的更多相关文章

  1. Ubuntu 14.04 LTS Server 无法挂载光盘 启动initramfs等问题

    今天需要在戴尔R410服务器上装64位的Linux,师兄给了个14.04的server 64位镜像.一开始打算用U盘安装,用软碟通烧写镜像之后,在服务器端设置从U盘启动,但是安装到一半出现了光盘无法挂 ...

  2. ubuntu 14.04 64位安装bigbluebutton

    BigBlueButton 是一个使用 ActionScript 开发的在线视频会议系统或者是远程教育系统,主要功能包括在线PPT演示.视频交流和语音交流,还可以进行文字交流.举手发言等功能,特别适合 ...

  3. Ubuntu 14.04下 Java通用安装方法

    参考: 解决Floodlight1.2+Mininet问题及使用安装 Ubuntu下安装JDK1.7图文详解 Ubuntu 14.04下 Java通用安装方法 1.到oracle官网下下载对应jdk包 ...

  4. Ubuntu 14.04中Elasticsearch集群配置

    Ubuntu 14.04中Elasticsearch集群配置 前言:本文可用于elasticsearch集群搭建参考.细分为elasticsearch.yml配置和系统配置 达到的目的:各台机器配置成 ...

  5. deepsooncms在Ubuntu 14.04上部署教程

    deepsooncms在Ubuntu 14.04上部署教程 一.安装mono1.在命令行运行sudo apt-key adv --keyserver keyserver.ubuntu.com --re ...

  6. Ubuntu 14.04 中 安装elasticsearch2.*+logstash2.*+kibana

    在Ubuntu 14.04 上安装单机版ELK 2.*(脚本化) 1.判断是否为root权限 if [ "${UID}" -ne 0 ]; then echo "You ...

  7. 【DDD/CQRS/微服务架构案例】在Ubuntu 14.04.4 LTS中运行WeText项目的服务端

    在<WeText项目:一个基于.NET实现的DDD.CQRS与微服务架构的演示案例>文章中,我介绍了自己用Visual Studio 2015(C# 6.0 with .NET Frame ...

  8. Ubuntu 14.04 LTS下安装Google Chrome浏览器

    在Ubuntu 14.04下安装Google Chrome浏览器非常简单,只要到Chrome的网站下载Deb安装包并进行安装即可.当然你也可以使用APT软件包管理器来安装Google Chrome浏览 ...

  9. 烂泥:ubuntu 14.04搭建OpenVPN服务器

    本文由秀依林枫提供友情赞助,首发于烂泥行天下 公司分部需要连接公司内部的服务器,但是该服务器只允许公司内部的网络访问. 为了解决这个问题,打算使用VPN.对于VPN以前使用最多的是PPTP这个解决方案 ...

  10. ubuntu 14.04 desktop装vnc4server

    ubuntu 14.04 desktop上安装vnc4server要装上gnome的一些软件包并修改启动文件~/.vnc/xstartup 问题来源How to make VNC Server wor ...

随机推荐

  1. Batch Size对神经网络训练的影响

    ​ 前言 这篇文章非常全面细致地介绍了Batch Size的相关问题.结合一些理论知识,通过大量实验,文章探讨了Batch Size的大小对模型性能的影响.如何影响以及如何缩小影响等有关内容. 本文来 ...

  2. jmeter设置为中文

    我的jmeter安装路径是在D:\Jmeter\apache-jmeter-5.1.1\bin. 设置中文有2种方法: 1.第一种方法:点击jmeter.bat进入jmeter界面,点击[option ...

  3. 防刷功能的实现(thinkphp5)

    $seconds = '3'; //时间段[秒] $refresh = '3';//最大次数 $cur_time = time(); if(Session::get('refresh_times')) ...

  4. Redis之品鉴之旅(七)

    分布式锁 1)阻塞锁: 尝试在redis中创建一个字符串结构缓存,方法传入的key,value为锁的过期时间timeout的时间戳. 若redis中没有这个key,则创建成功(即抢到锁),然后立即返回 ...

  5. [RabbitMQ]Java客户端:源码概览

    本文简要介绍RabbitMQ提供的Java客户端中最基本的功能性接口/类及相关源码. Mavan依赖: <dependency> <groupId>com.rabbitmq&l ...

  6. sql提示1055 不让你group by

    是不是突然写好的sql语句 部署上去就 Expression #2 of SELECT list is not in GROUP BY clause and containsnonaggregated ...

  7. 使用CSS选择器(第一部分)

    目录 使用CSS选择器(第一部分) 使用CSS基本选择器 选择所有元素 通用选择器 代码清单1 使用通用选择器 根据类型选择元素 元素类型选择器 代码清单2 使用元素类型选择器 提示 根据类选择元素 ...

  8. MyBatis概念和”安装“

    MyBatis概念 MyBatis的前身就是iBatis,本是apache的一个开源项目,2010年这个项目由apahce sofeware foundation 迁移到了google code,并且 ...

  9. CORS+XSS的漏洞利用payload

    之前有人问我有没有CORS+XSS的利用姿势,翻了一下国内貌似都没有利用姿势于是就写了这篇文章!!! 首先找到一个反射xss,然后使用xss加载javascript代码达到跨域劫持目的payload如 ...

  10. netty系列之:使用netty实现支持http2的服务器

    目录 简介 基本流程 CleartextHttp2ServerUpgradeHandler Http2ConnectionHandler 总结 简介 上一篇文章中,我们提到了如何在netty中配置TL ...