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