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列表。