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

你可能感兴趣的:(p4factory 入门)