专栏首页SDNLAB使用Python-Requests实现ODL对OVS的流表下发

使用Python-Requests实现ODL对OVS的流表下发

目标

  • 通过ODL,在OVS上添加如下的一个group

# ovs-vsctl add-br br0# ovs-vsctl set bridge br0 protocols=OpenFlow13# ovs-ofctl dump-groups br0 -O openflow13OFPST_GROUP_DESC reply (OF1.3) (xid=0x2): group_id=1,type=all,bucket=weight:0,set_field:00:00:00:00:00:05->eth_dst,set_field:192.168.100.105->ip_dst,output:5,bucket=weight:0,set_field:00:00:00:00:00:06->eth_dst,set_field:192.168.100.106->ip_dst,output:6,bucket=weight:0,set_field:00:00:00:00:00:07->eth_dst,set_field:192.168.100.107->ip_dst,output:7

准备工作

  • 运行ODL的Beryllium-SR3版本
  • Python 2.7
  • Requests :requests==2.2.1
  • 通过YangUI填写group所需信息,做PUT操作,抓取PUT的报文
  • 获取对应的Json字段
将JSON字段存入文件,供后面调用




$ cat odl.json
{
 "group": [
 {
 "group-type": "group-all",
 "group-id": "1",
 "buckets": {
 "bucket": [
 {
 "bucket-id": "0",
 "action": [
 {
 "order": "0",
 "set-field": {
 "ethernet-match": {
 "ethernet-destination": {
 "address": "00:00:00:00:00:05"
 }
 }
 }
 },
 {
 "order": "1',
                             "set-field": {
                                 "ipv4-destination": "192.168.100.105/32"
                             }
                         },
                         {
                             "order": "2",
                             "output-action": {
                                 "output-node-connector": "5"
                             }
                         }
                     ]
                 },
                 {
                     "bucket-id": "1",
                     "action": [
                         {
                             "order": "0",
                             "set-field": {
                                 "ethernet-match": {
                                     "ethernet-destination": {
                                         "address": "00:00:00:00:00:06"
                                     }
                                 }
                             }
                         },
                         {
                             "order": "1",
                             "set-field": {
                                 "ipv4-destination": "192.168.100.106/32"
                             }
                         },
                         {
                             "order": "2",
                             "output-action": {
                                 "output-node-connector": "6"
                             }
                         }
                     ]
                 },
                 {
                     "bucket-id": "2",
                     "action": [
                         {
                             "order": "0",
                             "set-field": {
                                 "ethernet-match": {
                                     "ethernet-destination": {
                                         "address": "00:00:00:00:00:07"
                                     }
                                 }
                             }
                         },
                         {
                             "order": "1",
                             "set-field": {
                                 "ipv4-destination": "192.168.100.107/32"
                             }
                         },
                         {
                             "order": "2",
                             "output-action": {
                                 "output-node-connector": "7"
 }
 }
 ]
 }
 ]
 }
 }
 ]
}

代码实现
  • 关键点有两个
    • ‘Content-Type’:’application/json’
    • Basic Authentication: admin/admin
  • 下面是参考代码

Java

$ cat odl_http.py 
#!/usr/bin/env python
import requests
from requests.auth import HTTPBasicAuth
def http_post(url,jstr):
 url= url
 headers = {'Content-Type':'application/json'}
 resp = requests.put(url,jstr,headers=headers,auth=HTTPBasicAuth('admin', 'admin'))
 return resp    
if __name__ == "__main__":
 url = 'http://10.10.11.80:8181/restconf/config/opendaylight-inventory:nodes/node/openflow:128983912192/flow-node-inventory:group/1'
 with open('odl.json') as f:
 jstr = f.read()
 resp = http_post(url,jstr)
 print resp.content
  • 在OVS查看流表,期望的group已经被添加成功。

本文分享自微信公众号 - SDNLAB(SDNLAB),作者:帅帅的

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-08-21

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

我来说两句

0 条评论
登录 后参与评论

相关文章

  • OVN实战二之Overlay实现

    前言 上一章介绍了GNS3的使用以及OVN系统的架构,搭建了实验环境,阐述了OVN各个进程的用途、彼此之间的关系,以及产生的日志(OVN实战一之GNS3操作指南...

    SDNLAB
  • SDNLAB群分享(四):利用ODL下发流表创建VxLAN网络

    今天想跟大家分享如何通过ODL控制器下发流表来创建VxLAN网络。ODL作为当前流行的控制器,已经有广泛的应用。基于ODL提供了丰富的北向接口,使得应用对网络有...

    SDNLAB
  • SDNLAB群分享(四):利用ODL下发流表创建VxLAN网络

    今天想跟大家分享如何通过ODL控制器下发流表来创建VxLAN网络。ODL作为当前流行的控制器,已经有广泛的应用。基于ODL提供了丰富的北向接口,使得应用对网络有...

    SDNLAB
  • 《连连看》算法c语言演示(自动连连看)

    俺踏月色而来
  • [042]f2fs存储结构初探

    将f2fs_device和loop设备绑定,生成一个虚拟块设备,如果提示设备忙,13换成其他数字

    王小二
  • 手搓一个分布式大气监测系统(三)使用 Nucleo LoRa 开发套件打造 PM2.5 监测终端

    鹅民大气监测项目前期已搭建了5个种子监测点,接下去将吸引更多的志愿者来搭建终端,接入系统,一起搭建监测网络。从二期开始,大气监测项目组的同事优选了几款开发套件完...

    twowinter
  • 为什么别人能用好 MySQL?万字详解其复杂原理

    MySQL InnoDB 引擎现在广为使用,它提供了事务,行锁,日志等一系列特性,本文分析下 InnoDB 的内部实现机制,MySQL 版本为 5.7.24,操...

    乔戈里
  • AkShare-宏观经济-中国LPR数据

    LPR数据对大家都有非常重大的影响,尤其是有房贷的各位小伙伴,特提供 LPR 数据接口,欢迎大家使用。

    AkShare
  • [Matlab]使用Simulink进行UDP通讯2

    原文链接:http://blog.csdn.net/humanking7/article/details/50710108

    祥知道
  • payload

    用户2657851

扫码关注云+社区

领取腾讯云代金券