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

    一、实验目的
    对 Python 调用 OpenDaylight 的 REST API 方法有初步了解。

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

    三、实验步骤

    1. 实验环境
      安装了 Ubuntu 18.04.5 Desktop amd64 的虚拟机

    2. 实验过程
      (1)生成拓扑

    (2)编写 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
    {
    "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 代码,完成流表下发
    先运行mn

    h1 ping h3
    再运行代码

    python odlnorth.py

    可以清晰的看到hardtimout 10s已生效

  • 相关阅读:
    关于MYSQL 和INNODB的逻辑关系图。最好的理解是一点点动手做,观察,记录,思考。
    MYSQL的DOUBLE WRITE双写
    MYSQL 中binlog 参数的记录
    How to install pip
    gdb
    vim的基本使用
    012_fieldset.html
    010_header.html
    011_label.html
    008_img.html
  • 原文地址:https://www.cnblogs.com/the-Wisdom-of-Ignorant/p/13847612.html
Copyright © 2011-2022 走看看