1. 解压安装OpenDayLight控制器(本次实验统一使用Beryllium版本)
(1)在虚拟机上查看java版本
java -version
(2)配置java环境
在虚拟机上找到java环境的相应位置进行配置
sudo gedit ~/.bashrc
在底部添加以下语句
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
(3)解压安装OpenDayLight控制器
从机房的虚拟机上拷贝安装包,然后用以下语句进行解压
tar -xf distribution-karaf-0.4.4-Beryllium-SR4.tar.gz
2. 启动并安装插件
(1)启动
进入ODL中bin的文件夹,运行./karaf(注意不能用sudo运行)
./karaf
(2)安装插件
feature:install odl-restconf
feature:install odl-l2switch-switch-ui
feature:install odl-openflowplugin-all
feature:install odl-mdsal-apidocs
feature:install odl-dlux-core
feature:install odl-dlux-node
feature:install odl-dlux-yangui
3. 用Python脚本搭建如下拓扑,连接OpenDayLight控制器
(1)搭建拓扑
from mininet.topo import Topo
class MyTopo(Topo):
def __init__(self):
# initilaize topology
Topo.__init__(self)
# add hosts and switches
h1 = self.addHost('h1')
h2 = self.addHost('h2')
h3 = self.addHost('h3')
s1 = self.addSwitch('s1')
# add links
self.addLink(h1, s1, 1, 1)
self.addLink(h2, s1, 1, 2)
self.addLink(h3, s1, 1, 3)
topos = {'mytopo': (lambda: MyTopo())}
用以下命令查看搭建结果:
sudo mn --custom /home/chanshanshan/sdn4.py --topo mytopo --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow13
(2)连接OpenDayLight控制器,控制器中的拓扑图如下
4. 在控制器提供的WEB UI中下发流表使h2 20s内ping不通h3,20s后恢复
- Yang UI>Opendaylight-inventory>config>nodes>table>flow
- node/openflow:1 交换机编号
- table/0 流表编号
- flow/不超过1024,不冲突即可 流表项编号
- GET为查询流表,下发流表要修改为PUT
(1)为了使h2 20s 内ping不通h3首先要知道h3和h1分别连接OVS的哪个端口,在mininet中用links查询链路连接情况
links
h2连接s1的port2
h3连接s1的port3
(2)由于连接上ODL默认ping通,所以下发策略使port2进来的目的IP为h3的数据包都drop掉就能ping不通(也可以反过来使port3进来的目的IP为h2的IP的数据包drop),同时设置hard_time为20s,则20s后策略失效。
相关值设置如下:
为了保证流表生效,把优先级设成最大,65535
(3)验证流表下发成功
在mininet中h2 ping h3,点击send,由于设置了hard_time为20s,所以icmp_seq延迟20s
5. 借助Postman通过OpenDayLight的北向接口下发流表,再利用OpenDayLight北向接口查看已下发的流表。
安装并解压Postman,进入Postman界面。
通过preview查看刚刚下发的流表项的json格式
http://127.0.0.1:8181/restconf/config/opendaylight-inventory:nodes/node/1/flow-node-inventory:table/0/flow/1
{
"flow": [
{
"id": "1",
"match": {
"in-port": "2",
"ethernet-match": {
"ethernet-type": {
"type": "2048"
}
},
"ipv4-destination": "10.0.0.3/32"
},
"instructions": {
"instruction": [
{
"order": "0",
"apply-actions": {
"action": [
{
"order": "0",
"drop-action": {}
}
]
}
}
]
},
"priority": "65535",
"hard-timeout": "20",
"cookie": "2",
"table_id": "0"
}
]
}
把preview里的url复制到地址栏,消息方式选择PUT,type设置为Basic Auth,填写账户和密码,选择raw,JSON格式,通过send查看刚刚下发的流表。
在mininet中h2 ping h3
在20s内,把消息方式选择改成GET