軟體定義網路-實驗 7:OpenDaylight 實驗——Python 中的 REST API 呼叫
阿新 • • 發佈:2020-10-14
一、實驗目的
對 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 --switchovsk,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