SDN开发笔记(二):SDN控制器的使用

鉴于网上对于sdn开发相关的资料较少又乱的现状,从这篇文章开始,我将陆续分享我在sdn开发过程中的经验,我的sdn项目开发是基于opendaylight的release-lithium-sr3版本,该版本相对稳定。

继上篇文章《sdn开发环境的搭建(win7环境)- SDN开发笔记(一)》之后,我在Linux下使用odl控制器,在使用之前,先将使用环境搭建好,我使用的Linux是ubuntu 14.04桌面版,采用vmware虚拟机方式,具体为:

Vmware版本:VMware-workstation-full-11.1.0

Linux版本:ubuntu-14.04-desktop-amd64.iso

一、基本环境搭建

1、安装Vmware并注册key

2、安装ubuntu-14.04-desktop,具体安装过程请自行google下

3、启用linux的root账号、ssh-service允许远程连接等,此步骤可忽略,目的只是方便odl控制器文件传输等。

二、ODL运行环境搭建

1、JDK环境搭建

JDK版本使用jdk-8u73-linux-i586.gz,新建目录/usr/lib/jvm,并将jdk解压至该目录,修改目录名称为java。

mkdir /usr/lib/jvm

tar -zxvf jdk-8u73-linux-i586.gz -C /usr/lib/jvm

mv jdk_8u_73 java

2、Maven环境搭建,选择apche-maven-3.3.9-bin.tar.gz,解压到/usr/jvm/maven。

tar -zxvf apche-maven-3.3.9-bin.tar.gz -C /usr/lib/jvm

3、设置环境变量

vi ~/.bashrc

最末尾添加如下:

export JAVA_HOME=/usr/lib/jvm/java

export JRE_HOME=${JAVA_HOME}/jre

export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib:${CLASSPATH}

export M2_HOME=/usr/lib/maven/maven

export MAVEN_OPTS="-Xmx1024M -XX:MaxPermSize=512m"

export PATH=${JAVA_HOME}/bin:${JRE_HOME}/bin:${M2_HOME}/bin:$PATH

保存退出,使之生效

source ~/.bashrc

4、验证环境是否ok,在终端输入 mvn -v

5、从官网下载发行版二进制odl控制器文件,传入ubuntu中,解压,找到distribution-karaf-0.3.3-Lithium-SR3/bin/karaf文件。

解释下,karaf.bat文件是在windows环境的启动文件,而karaf是Linux环境下的启动文件,Odl控制器是支持在windows和Linux环境两种环境运行的,因为ODL控制器是运行在JVM之上的。

6、运行karaf,启动odl控制器。

./karaf

可以看到运行界面如下

二、mininet的使用

1、mininet的安装

我选择的是直接git下载,执行以下步骤将mininet安装

#git clone git://github.com/mininet/mininet

#cd mininet

#git tag

#git checkout -b 版本号

#cd util

#./install.sh -a

安装ovs

#apt-get update

#apt-cache search openvswitch

#apt-get install openvswitch-switch

2、测试是否成功

测试是否成功

sudo mn --test pingall

查看mininet版本

#mn --version

查看OVS版本

#ovs-ofctl –version

出现以下则表示安装mininet等ok

3、mininet的使用

启动好odl之后,就可以运行mininet连接odl控制器了,但是前提是odl需要安装几个feature,比如odl-dlux-all用于web浏览器访问odl,odl-l2switch-all用于发现主机节点,odl-restconfig-all用于访问北向接口。在odl控制台中执行

feature:install odl-dlux-all

feature:install odl-l2switch-all

feature:install odl-restconf-all

可以通过feature:list -i已安装feature,通过http:list | grep dlux 查看dlux的load情况

4、通过web浏览器访问http://192.168.65.129:8181/index.html

注意192.168.65.129是我运行odl控制器的ip,输入admin/admin登录可以看到web页面如下:

目前由于没有连接mininet,因此没有任何设备在页面。

5、运行mininet连接odl,在终端输入

mn --controller=remote,ip=192.168.65.129,port=6653

注意最新的mininet已经改用6653端口而非6633端口连接odl控制器

6、刷下web页面,可以看到一台交换机,此时在mininet中输入pingall,web页面就可看到两台主机与一台交换机。

7、重要的地方

http://192.168.65.129:8181/restconf/operational/opendaylight-inventory:nodes/node/openflow:1

这个链接用于查看在odl上的交换机与主机节点信息。

mininet控制台除了上述的pingall、dump还有其他有用的命令,比如net、ovs-ofctl、link等命令,在mininet上使用”?”就可以显示所有命令,命令详情请自行google一下。

原文发布于微信公众号 - SDNLAB(SDNLAB)

原文发表时间:2016-07-12

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java开发

搭建 ElasticSearch 6.1.3分布式集群

先启动mac上的master,再启动Ubuntu上的slave节点,观察输出,会有一个node-102探测到master节点的提示:

21910
来自专栏云计算教程系列

在腾讯云CVM上安装熟悉Node.js

Node.js是一个开源JavaScript运行环境,用于轻松构建服务器端和网络应用程序。该应用程序可在Linux,OS X,FreeBSD和Windows上运...

32050
来自专栏行者常至

003.多线程-主线程、守护线程、用户线程的区别

守护线程: 主要是指 在进程中,为主线程提供一种通用服务的线程。 比如 gc线程 因为,主线程一旦结束或者销毁, 守护线程没有了守护对象, 也将同步进...

29640
来自专栏自动化测试实战

Git教程——撤销内容修改和版本回退

2K100
来自专栏Java技术分享

手把手教你用Mysql-Cluster-7.5搭建数据库集群

当你的业务到达一定的当量,肯定需要一定数量的数据库来负载均衡你的数据库请求,我在之前的博客中已经说明了,如何实现负载均衡,但是还有一个问题就是数据同步,因为负载...

57480
来自专栏LuckQI

linux实战应用~redis集群(阿里面试可能会问的)

16430
来自专栏Python小屋

Python安装扩展库与打包成exe可执行文件的方法

1、安装扩展库的几种方法。 首先可能需要使用 pip install --upgrade pip 来升级本机的pip程序。然后在命令提示符环境(即cmd方式)执...

37660
来自专栏企鹅号快讯

基于python3.5+的web框架sanic中文入门

sanic是一款用 python3.5+ 写的 web framework,用法和 flask 类似,特点是非常快。 Github 官网:https://git...

29070
来自专栏简单聊聊Spark

大数据在实际生产环境的前期准备

eg:  bigdata-cdh01.test.com. bigdata-cdh02.test.com. bigdata-cdh03.test.com

16630
来自专栏LEo的网络日志

如何通过criu checkpoint/restore应用

15720

扫码关注云+社区

领取腾讯云代金券