p4factory 入門

p4factory 入門

2/22/2017 10:56:05 AM


p4factory的安裝與測試

首先從github上clone一個p4factory到本地計算機:

git clone https://github.com/p4lang/p4factory

clone完成後,進入p4factory目錄下,更新該倉庫的子模塊。然後運行install_deps.sh腳本,安裝Ubuntu 14.04的依賴項。注意操作系統必須是Ubuntu 14.04哦,最好是64位。因爲後面可能需要安裝Docker,Docker官方提供的安裝包的系統要求必須是64位,如果你的系統是32位的話,可能需要下載Docker源代碼自己編譯32位版本

git submodule update --init --recursive
./install_deps.sh

安裝依賴項會花上一段時間,終端顯示腳本編譯了一堆東西,這段時間可以來看看電影,泡杯咖啡。安裝完依賴項之後,你需要創建用來連接模擬器的veth接口:

sudo p4factory/tools/veth_setup.sh

運行結束後我們就可以用autoconf工具生成makefiles:

cd p4factory
./autogen.sh
./configure

完成上述配置後,我們用一個簡單的P4程序運行模擬器來驗證我們的程序是否安裝正確:

cd p4factory/targets/basic_routing/
make bm
sudo ./behavioral-model

然後打開另一個終端,運行下面的命令:

cd p4factory/targets/basic_routing/
sudo python run_tests.py --test-dir tests/ptf-tests/

建立並運行一個P4程序

每個P4程序都被放在targets/文件夾下,建立一個P4程序(target)”project_name”,需要運行下面的命令:

cd targets/project_name
make bm

運行結束後,會在當前目錄下生成一個名爲“behavioral_model”的可執行文件。

與Mininet集成

我們用已有的P4程序(simple_router)來做一個與Mininet的集成:

cd p4factory/targets/simple_router/
make bm
./run_demo.bash

然後安裝一些表項(在另一個終端中運行下面命令):

./run_add_demo_entries.bash

然後在mininet中輸入下面的命令,這裏要注意,mininet要用p4lang/mininet,因爲這裏交換機ovs被替換了,如果使用mininet官方的代碼mininet/mininet,在運行run_demo.bash腳本時就會出錯

mininet> h1 ping h2

問題處理

當出現run_add_demo_entries.bash不能正常工作或類似的問題時,可以嘗試執行下面的命令:

sudo mn -c 
sudo killall behavioral-model 
redis-cli FLUSHALL

其他問題可以查詢p4lang/p4factory的issue列表。

發佈了15 篇原創文章 · 獲贊 12 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章