基于OpenDaylight和Mininet的试验床平台搭建

##########################################平台架构#########################################

一、虚拟机安装和镜像加载

*本部分过程非常简单,所以不详细描述,基本流程稍微提一下。

1. 虚拟机软件:安装虚拟机软件主要有VMware Station, VirtualBox等,后者免费,下载网址为:https://www.virtualbox.org/wiki/Downloads,本文以VMware Station为例。请自行下载安装,这里不多做赘述。

2. Ubuntu系统加载:到Ubuntu官网下载自身操作系统对应的最新版Ubuntu桌面镜像,通过VMware加载Ubuntu镜像。

3. Mininet VM加载:到Mininet官网:http://mininet.org/vm-setup-notes/下载镜像文件(打开网页后有相关指南,可以参照其进行加载安装,懒得看英文的话就只用先把Mininet镜像导入VMware,不用启动,后文会对这里接下来的操作进行详述)。

4. 最后Ubuntu部分的相关配置参数如下图,Mininet的导入不需要进行任何参数配置,至少在启动前不用。注意虚拟机网卡都是默认的NAT模式不用更改。

二、Ubuntu系统下OpenDaylight安装

*本部分操作比较多,因此针对每一步都另文给出详细步骤:

1. Ubuntu系统中搭建Java开发环境:《Linux Ubuntu系统下Java开发环境搭建》

2. Ubuntu系统中安装Apache Maven:《Linux Ubuntu系统下Apache Maven的安装和配置》

3. Ubuntu系统中安装OpenDaylight:《SDN开发之Linux Ubuntu系统下OpenDaylight源码编译安装和调试》

三、OpenDaylight功能组件安装和调试

*本部分解决OpenDaylight控制器和Mininet的连接,并且通过OpenDaylight DLUX的Web GUI显示。

*本部分基于上文步骤全部完成,已经搭建了一个初步装好OpenDaylight的Ubuntu虚拟机。

*下文用ODL指代OpenDaylight。

1. 一键启动控制器:ODL每次启动controller需要cd目录十分麻烦。这里同样可以自己写一个启动脚本来管理ODL控制器的运行:

vim odl
<Insert>
!#/bin/bash
/home/<usrname>/developApps/openDayLight/integration/distributions/karaf/target/assembly/bin/karaf
<Esc>
:wq!
sudo mv odl /usr/local/bin
sudo chmod 755 /usr/local/bin/odl

这样在任何地方都只用输入(sudo -i) odl就可以运行控制器了。

2. OpenDaylight的Features安装和调试。

现在就可以输入odl命令来启动控制器了,先进入如下界面:

安装支持REST API的组件:

feature:install odl-restconf

安装L2 switch和OpenFlow插件:

feature:install odl-l2switch-switch

feature:install odl-openflowplugin-all

安装基于karaf控制台的md-sal控制器功能,包括nodes、yang UI、Topology:

feature:install odl-mdsal-apidocs    #此组件写错 很容易无法登录

安装DLUX功能:

feature:install odl-dlux-all

安装基于karaf控制台的ad-sal功能,包括Connection manager、Container、Network、Flows:

feature:install odl-adsal-northbound

*注意:请按照一定的顺序安装,安装顺序不合理的话,会导致后面Web界面无法访问!且记录遇到的一个问题:在没有按照顺序安装组件的情况下,无法登录进入ODL主界面。解决方法是通过logout退出karaf平台,进入上级目录,删除data目录:rm –r data,进入bin目录:cd bin,执行./karaf clean,再次重复上面的安装组件操作。

(本部分摘自:《OpenDaylight的Helium(氦)版本安装》@君子一诺 )

Web界面访问:此时可以登录ODL的Web UI界面进行访问。用浏览器访问网址:http://<ODL的IP>:8181/dlux/index.html,<ODL_IP>为安装ODL所在的主机IP地址,特别注意的是此版本的ODL访问端口为8181,因8080端口被karaf控制台进程所占用。某些情况下不需要进入/dlux目录而直接访问http://<ODL的IP>:8181/index.html。

登陆用户名为admin,密码为admin,如下图:

*关于Features出问题,可以vim查看/developApps/openDayLight/integration/distributions/karaf/target/assembly/etc目录下的org.apache.karaf.features.cfg

*由于还没有连接数据面Mininet的交换机,因此登陆进去后还不会显示任何拓扑。

四、Mininet虚拟机的安装和登录调试

*本部分接着第一部分下载好Mininet镜像后,解决Mininet导入虚拟机后的加载配置并重点阐述远程免密码自动登录的设置。

1. 在虚拟机成功导入.OVF后缀的mininet文件后,直接启动。

2. 启动完成后,进入到登录界面,账号密码都是mininet(注意密码敲了不会有显示很正常,敲完再敲回车就行)。

mininet-vm login: mininet
Password: mininet      

3. 好,重点来了,接下来说明如何从Ubuntu的虚拟机"远程"SSH登录到Mininet,这样做的目的是可以避免在两个虚拟机之间切来切去的麻烦。

a)首先,需要找到Mininet虚拟机的IP地址,一般是192.168.x.y格式的地址。在Mininet的命令行界面输入:

ifconfig eth0          

b)如果你不希望每次从Ubuntu虚拟机SSH登录Mininet的时候都输一遍这个 IP地址,可以在Ubuntu虚拟机端修改一下/etc/hosts文件:

sudo gedit /etc/hosts          

然后在文档末尾添加以下内容后保存退出:

192.168.x.y minivm

这样就可以在每次登陆的时候用“minivm”代替IP地址。

c)接下来就可以从Ubuntu虚拟机端SSH到Mininet了。在Ubuntu端终端输入以下命令(没有修改hosts文件的话就用mininet的IP地址代替minivm):

ssh -Y [email protected]    

d)登陆后输入账号mininet密码mininet,就到了Mininet的命令行界面了。

4.(可选)写脚本一键SSH免密码自动登录Mininet。

每次都要手动敲命令还要输入账号密码登陆Mininet稍显麻烦,我们还可以做出如下简化:

a)设置免密码登陆:在Ubuntu端check一下是否已经有SSH密钥:    ~/.ssh/id_rsa     或者     ~/.ssh/id_dsa    

如果都不能找到任何文件的话,那么就需要通过命令生成SSH密钥,同样在Ubuntu端:       ssh-keygen -t rsa        

为了加快以后SSH连接的速度,需要将你的公钥添加给Mininet端。同样在Ubuntu端:     scp ~/.ssh/id_rsa.pub [email protected]:~/     

最后,在Ubuntu端先通过SSH登陆进Mininet,再在Mininet命令行模式下输入:

cd ~/ && mkdir -p .ssh && chmod 700 .ssh && cd .ssh && touch authorized_keys2 && chmod 600 authorized_keys2 && cat ../id_rsa.pub >> authorized_keys2 && rm ../id_rsa.pub && cd ..      

操作完成后,以后每次登陆就不必输入账号密码了。

b)写一键登陆脚本:嫌输命令麻烦的童鞋还可以继续写一个脚本,输入:(其中<>表示按键)

vim mininet
    <Insert>(在文档内添加以下内容)
    !#/bin/bash
    ssh -Y [email protected]
    <Esc>
    :wq!
    sudo mv mininet /usr/local/bin
    sudo chmod 755 /usr/local/bin/mininet

这样以后在Ubuntu端每次只用通过mininet命令来一键登陆Mininet。

五、OpenDaylight+Mininet联动

*本部分测试ODL和Mininet的连接,初步搭建好一个SDN试验床。

1. 启动MIninet和ODL。调试好网络连接。首先通过一端Ping另一端测试网络连通性。

2. 通过"minivm"命令运行脚本登陆Mininet:创建简单实验拓扑并指定远程ODL作为控制器,简单的命令可以尝试:

sudo mn --controller=remote,ip=<ODL的IP>        

完成后将输出一下内容:

[email protected]:~$ sudo mn --controller=remote,ip=192.168.174.128
*** Creating network
*** Adding controller
*** Adding hosts:
h1 h2
*** Adding switches:
s1
*** Adding links:
(h1, s1) (h2, s1)
*** Configuring hosts
h1 h2
*** Starting controller
c0
*** Starting 1 switches
s1 ...
*** Starting CLI:
mininet>

3. 打开网页登陆ODL的Web界面,看到如图拓扑,联动测试完成,一个基本的基于ODL+Mininet的SDN实验平台就搭建好了!

祝顺利!

时间: 2024-10-23 00:52:09

基于OpenDaylight和Mininet的试验床平台搭建的相关文章

Floodlight+Mininet的SDN实验平台搭建初探

平台环境说明: Cpu:Intel Core 2 Duo T6570 Mem:4.00GB Os :Ubuntu 14.04 1.Floodlight Floodlight是一个比较成熟的sdn控制器实现,其中opendaylight项目中也采用了它的很多实现方法,官方网站:http://www.projectfloodlight.org/floodlight/.本文采用它作为控制器,采用包含mininet的虚拟机作网络拓扑,两者结合模拟显示网络. Floodlight安装: A. $ sudo

基于OneMap的水利行业共享服务平台搭建步骤

今天上午再次学习Esri技术培训中心的“GIS服务共享与运维管理——之OneMap解决方案”课程,从中学习了OneMap的产品架构以及基于OneMap共享服务平台的搭建步骤.下面把其中水利行业的共享服务平台的搭建主要步骤整理如下: 搭建水利共享服务平台主要为水利行业各个不同业务领域.不同业务部门共同使用, 主要的搭建步骤有, 一.平台数据资源组织 (1)建立数据中心,汇集之前“各自为政”的各个业务系统的业务数据.建设数据模型和数据仓库,对汇集好的所有数据进行统一的管理.通过行业共享服务平台,将收

Go 语言开发的基于 Linux 虚拟服务器的负载平衡平台 Seesaw

负载均衡系统 Seesaw Seesaw是由我们网络可靠性工程师用 Go 语言开发的基于 Linux 虚拟服务器的负载平衡平台,就像所有好的项目一样,这个项目也是为了解决实际问题而产生的. Seesaw发布的博客中这样写道:“我们需要能够处理单播(unicast)和任播(anycast)虚拟 IP (VIPs) 流量,使用 NAT 和 DSR (也被称为 DR) 执行负载均衡,执行针对后端的健康检查.特别是,我们需要一个容易管理的平台,可以自动部署配置的变化.在评估了一些包括现有的开源项目的平台

基于rhel7.2的Zabbix平台搭建和部署(一)

基于rhel7.2的zabbix平台搭建和部署(一) 一.实验环境: (1)虚拟机:rhel7.2 x86_64 (2)数据库:mysql5.7.13 (3)nginx1.10.2 (4)PHP5.6.27 (5)zabbix 二.安装编译工具及库文件 [[email protected] ~]# yum-y install make apr* autoconf automake curl-devel gcc gcc-c++  openssl openssl-devel gd kernel ke

基于CCS3.3平台搭建DSP/BIOS系统

本人由于换工作的原因,由ccs3.1平台下转化为ccs3.3平台.先说说本人感觉的区别,ccs3.1下的CSL库集成到DSP/BIOS内,而3.3的CSL库在DSP/BIOS下就没有体现. 1.二话不说,先搭建CCS3.3的工程,添加main函数.这个比较简单就不细说了. 2.创建DSP/BIOS文件.File->New->Dsp/bios Configuration,然后 [保存] 3.把BIOS文件参加到工程里去.(3.1为.cbd文件,而3.3为.tcf文件) 4.编译会报出堆空间不能为

基于rhel7.2的Zabbix平台搭建和部署(四)

基于rhel7.2的Zabbix平台搭建和部署(四) 一.实现zabbix添加监测项,添加对Linux主机的监控. 说明:先在"配置"-"主机"里添加主机监控,监控os资源:内存,cpu,io,负载,带宽等. (1)登录zabbix,先在"配置"-"主机"里单击"创建主机": (2)在"主机"标签,填写相关信息 注:这个主机名字必须和hostname的一模一样,这里用的ip就是被监控主机

基于rhel7.2的Zabbix平台搭建和部署(二)

 基于rhel7.2的Zabbix平台搭建和部署(二) 一.监控系统Zabbix-3.2.1的安装 zabbix-server端的操作 说明:zabbix服务器端要提前安装好LNMP环境(mysql,nginx,php5的安装目录均是/usr/local) (1)创建zabbix运行的用户 [[email protected] ~]# groupadd zabbix [[email protected] ~]# useradd -g zabbix [[email protected] ~]# g

基于rhel7.2的Zabbix平台搭建和部署(五)

基于rhel7.2的Zabbix平台搭建和部署(五) zabbix3.2.1邮件报警设置 说明:zabbix监控服务端.客户端都已经部署完成,被监控主机已经添加,zabiix监控运行正常. 在zabbix服务端设置邮件报警,当被监控主机宕机或者达到触发器预设值时,会自动发送报警邮件到指定邮箱. 一.zabbix报警部署步骤(操作在Zabbix监控服务端进行): 安装sendmail两个依赖包 [[email protected] ~]# yum install -y perl-Net-SSLea

基于H3C CAS的云计算平台搭建

基于H3C CAS的云计算平台搭建 1.H3C CAS介绍 H3C CAS(CloudAutomation System)云计算管理平台是H3C 公司推出的构建云计算基础架构的资源管理平台,它为数据中心云计算基础架构提供虚拟化管理解决方案,实现对数据中心云计算环境的集中管理和控制.此外,CAS 还支持vStor 分布式存储管理功能,即整合多个宿主机内的硬盘资源,构建IP SAN 提供给本云计算资源平台或其他业务系统使用. 2.产品组件 CAS 由四个组件构成: CVK(Cloud Virtual