zoukankan      html  css  js  c++  java
  • 实验 7:OpenDaylight 实验——Python 中的 REST API 调用

    实验目的

    对 Python 调用 OpenDaylight 的 REST API 方法有初步了解。

    实验任务

    本实验需要用另一种方法完成上一个实验相同的功能,即通过 Python 程序调用OpenDaylight 的北向接口下发关于硬超时的流表,实现拓扑内主机在一定时间内的网络通断。实验拓扑如下:

    实验步骤

    实验环境

    Ubuntu 18.04.1 x86_64

    实验过程

    生成拓扑

    sudo mn --topo=single,3 --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow13
    

    生成拓扑的方法同之前的实验一致。

    编写 Python 代码和 JSON 格式的请求内容

    #!/usr/bin/python
    import requests
    from requests.auth import HTTPBasicAuth
    def http_put(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://127.0.0.1:8181/restconf/config/opendaylight-inventory:nodes/node/openflow:1/flow-node-inventory:table/0/flow/1'
    	with open('hardtimeout.json') as f:
    		jstr = f.read()
    	resp = http_put(url,jstr)
    	print resp.content
    

    由于是下发流表,因此需要有 http 请求的具体内容,同之前的 Postman 一样,也是以 JSON 格式来表示。
    编辑 hardtimeout.json 文件:

    {
    "flow": [
    {
    "id": "1",
    "match": {
    "in-port": "1",
    "ethernet-match": {
    "ethernet-type": {
    "type": "0x0800"
    }
    },
    "ipv4-destination": "10.0.0.3/32"
    },
    "instructions": {
    "instruction": [
    {
    "order": "0",
    "apply-actions": {
    "action": [
    {
    "order": "0",
    "drop-action": {}
    }
    ]
    }
    }
    ]
    },
    "flow-name": "flow1",
    "priority": "65535",
    "hard-timeout": "10",
    "cookie": "2",
    "table_id": "0"
    }
    ]
    }
    

    (3)运行 Python 代码,完成流表下发

    python odlnorth.py
    

    h1 ping h3 有 10 秒时间(5-14)是中断的,结果符合预期。

    更多 OpenDaylight 的 REST API 文档可以在下面的地址中查找:http://127.0.0.1:8181/apidoc/explorer/index.html

    实验总结

    python代码的编写中要注意缩进格式

  • 相关阅读:
    常见排序算法的实现和比较
    关于数据库索引的原理和应用
    数据库查询优化的几种方式
    进程间通信的几种方式
    TCP的三次握手和四次分手
    【面试题35】第一个只出现一次的字符
    【面试题34】丑数
    【面试题33】把数组排成最小的数
    【面试题32】从1到n整数中1出现的次数
    简单工厂模式
  • 原文地址:https://www.cnblogs.com/fzulinxin/p/13815507.html
Copyright © 2011-2022 走看看