1. 程式人生 > 實用技巧 >軟體定義網路-實驗 7:OpenDaylight 實驗——Python 中的 REST API 呼叫

軟體定義網路-實驗 7:OpenDaylight 實驗——Python 中的 REST API 呼叫

一、實驗目的

對 Python 呼叫 OpenDaylight 的 REST API 方法有初步瞭解。

二、實驗任務

本實驗需要用另一種方法完成上一個實驗相同的功能,即通過 Python 程式呼叫 OpenDaylight 的北向介面下發關於硬超時的流表,實現拓撲內主機在一定時間 內的網路通斷。實驗拓撲如下:

三、實驗步驟

1. 實驗環境

安裝了 Ubuntu 18.04.5 Desktop amd64 的虛擬機器

2. 實驗過程

(1)生成拓撲

開啟控制器

生成拓撲並測試是否ping通

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

(2)編寫 Python 程式碼和 JSON 格式的請求內容

$ nano odlnorth.py
 1 #!/usr/bin/python
 2 
 3 import requests
 4 from requests.auth import HTTPBasicAuth
 5 
 6 def http_put(url,jstr):
 7  url= url
 8  headers = {'Content-Type':'application/json'}
 9  resp = requests.put(url,jstr,headers=headers,auth=HTTPBasicAuth('
admin', 'admin')) 10 return resp 11 12 if __name__ == "__main__": 13 url = 'http://127.0.0.1:8181/restconf/config/opendaylight-inventory:nodes/node/openflow:1/flownode-inventory:table/0/flow/1' 14 with open('hardtimeout.json') as f: 15 jstr = f.read() 16 resp = http_put(url,jstr) 17 print resp.content

由於是下發流表,因此需要有 http 請求的具體內容,同之前的 Postman 一樣, 也是以 JSON 格式來表示。 編輯 hardtimeout.json 檔案:由於是下發流表,因此需要有 http 請求的具體內容,同之前的 Postman 一樣, 也是以 JSON 格式來表示。 編輯 hardtimeout.json 檔案:

$ nano hardtimeout.json

檔案中不包含 http 請求的 url 地址

 1 {
 2  "flow": [
 3  {
 4  "id": "1",
 5  "match": {
 6  "in-port": "1",
 7  "ethernet-match": {
 8  "ethernet-type": {
 9  "type": "0x0800"
10  }
11  },
12  "ipv4-destination": "10.0.0.3/32"
13  },
14  "instructions": {
15  "instruction": [
16  {
17  "order": "0",
18  "apply-actions": {
19  "action": [
20  {
21  "order": "0",
22 "drop-action": {}
23  }
24  ]
25  }
26  }
27  ]
28  },
29  "flow-name": "flow1",
30  "priority": "65535",
31  "hard-timeout": "10",
32  "cookie": "2",
33  "table_id": "0"
34  }
35  ]
36 }

(3)執行 Python 程式碼,完成流表下發

$ python odlnorth.py

h1 ping h3測試結果

四、實驗心得

執行程式碼如果報錯:ImportError: No module named requests,可嘗試 如下方法。

1 $ sudo apt-get install python-pip //如果 pip 沒裝的話需要執行
2 $ sudo pip install requests