作者:Savithru Lokanath 译者:TF编译组
TF-Netronome体系架构
Lab设置
准备条件
· 至少两个节点:一个控制器节点 一个计算节点
· Ubuntu 14.04.4(3.13.0-100 Errata 47 patched kernel)
· TF- Cloud 3.1.2.0-65(OpenStack Kilo/Mitaka)
· Agilio vRouter 3.1.0.0-124
Netronome SmartNIC安装指南(新装)
注意:本指南假定您已经在服务器上插入了Netronome NIC。
在所有节点上
· 在设置中的所有节点上安装Ubuntu 14.04.4
· 在节点上下载并安装Tungsten Fabric软件包
代码语言:javascript复制 (all-nodes)# dpkg -i contrail-install-packages_3.1.2.0-65~mitaka_all.deb
(all-nodes)# /opt/contrail/contrail_packages/setup.sh
(all-nodes)# apt-get update
· 下载Netronome(Agilio vRouter)软件包并复制到所有节点
代码语言:javascript复制 (all-nodes)# tar -xvf ns-agilio-vrouter-release_3.1.0.0-124.tgz
(all-nodes)# cd ns-agilio-vrouter-release_3.1.0.0-124/
(all-nodes)# cp ns-agilio-vrouter-depends-packages_3.1.0.0-124_amd64.deb /opt/contrail/contrail_install_repo/
(all-nodes)# cd /opt/contrail/contrail_install_repo/
(all-nodes)# dpkg-scanpackages . /dev/null | gzip -9c > Packages.gz
(all-nodes)# apt-get update
在控制器节点上
· 用相关信息填充测试平台
代码语言:javascript复制 (controller-node)# vim /opt/contrail/utils/fabfile/testbeds/testbed.py
bond= {
compute1 : { 'name': 'bond0', 'member': ['nfp_p0','nfp_p1','nfp_p2','nfp_p3'], 'mode': '802.3ad',
'xmit_hash_policy': 'layer3 4' },
compute2 : { 'name': 'bond0', 'member': ['nfp_p0','nfp_p1','nfp_p2','nfp_p3'], 'mode': '802.3ad',
'xmit_hash_policy': 'layer3 4' },
}
control_data = {
controller : { 'ip': '172.31.255.1/24', 'gw' : '172.31.255.1', 'device': 'eth1' },
compute1 : { 'ip': '172.31.255.2/24', 'gw' : '172.31.255.1', 'device': 'bond0' },
compute2 : { 'ip': '172.31.255.3/24', 'gw' : '172.31.255.1', 'device': 'bond0' },
}
env.ns_agilio_vrouter = {
compute1: {'huge_page_alloc': '24G', 'huge_page_size': '1G', 'coremask': '2,4', 'pinning_mode':
'auto:split'},
compute2: {'huge_page_alloc': '24G', 'huge_page_size': '1G', 'coremask': '2,4', 'pinning_mode':
'auto:split'}
}
示例文件请见:https://github.com/savithruml/netronome-agilio-vrouter/tree/3.1.2/testbed
· 启用Netronome SmartNIC
代码语言:javascript复制 (controller-node)# cd /opt/contrail/utils/
(controller-node)# fab install_ns_agilio_nic
(controller-node)# reboot
(controller-node)# fab install_ns_agilio_nic
注意:您可能会遇到“在目标节点上找不到python-dev软件包”的错误。
代码语言:javascript复制 (target-node)# aptitude install python-dev
在第一个提示中选择“否”,在第二个提示中选择“是”。重新运行fab install_ns_agilio_nic
代码语言:javascript复制 (controller-node)# fab install_ns_agilio_nic
· 如果您使用的是分支电缆(4×10GbE → 1×40GbE),请更改SmartNIC的media配置。
代码语言:javascript复制 This should create four NFP interfaces: nfp_p0, nfp_p1, nfp_p2, nfp_p3
(compute-node)# /opt/netronome/bin/nfp-media --set-media=phy0=4x10G
(compute-node)# service ns-core-nic.autorun clean
(compute-node)# reboot
· 安装Tungsten Fabric
代码语言:javascript复制 (controller-node)# cd /opt/contrail/utils
(controller-node)# fab install_contrail
注意:您可能会遇到“在目标节点上找不到default-jre-headless软件包”的错误。
代码语言:javascript复制 (target-node)# aptitude install default-jre-headless
在第一个提示中选择“否”,在第二个提示中选择“是”。重新运行fab install_contrail
代码语言:javascript复制 (controller-node)# fab setup_interface (Verify if all nodes can talk with each other on Control/Data interface)
(controller-node)# fab setup_all
在Netronome计算节点上
· 验证预配是否成功
代码语言:javascript复制 (compute-nodes)# contrail-status
(compute-nodes)# /opt/netronome/libexec/nfp-vrouter-status -r
· 创建VirtIO flavors
注意:仅执行一次
代码语言:javascript复制 (compute-node)# cd /ns-agilio-vrouter-release_3.1.0.0-124/ns-agilio-vrouter_3.1.0.0-124/opt/netronome/openstack
(compute-node)# ./make_virtio_flavors.sh <controller-ip-address>
Netronome SmartNIC安装指南(现有设置)
注意:本指南假定您已经在服务器上插入了Netronome NIC。
在新的Netronome计算节点上
· 安装所需的Linux内核
代码语言:javascript复制 (compute-node)# apt-get install linux-image-3.13.0-100-generic
(compute-node)# apt-get install linux-headers-3.13.0-100-generic
(compute-node)# apt-get install linux-image-extra-3.13.0-100-generic
(compute-node)# apt-get install linux-image-generic
(compute-node)# apt-get install linux-generic
在/etc/default/grub目录中,确保
代码语言:javascript复制 GRUB_DEFAULT='1>Ubuntu, with Linux 3.13.0-100-generic'
GRUB_CMDLINE_LINUX_DEFAULT="intel_iommu=on iommu=pt intremap=on"
(compute-node)# update-grub
(compute-node)# reboot
· 安装NFP所需项
代码语言:javascript复制 (compute-node)# apt-get install dkms libftdi1 libjansson4
· 下载Netronome(Agilio vRouter)软件包
代码语言:javascript复制 (compute-node)# tar -xvf ns-agilio-vrouter-release_3.1.0.0-124.tgz
(compute-node)# cd ns-agilio-vrouter-release_3.1.0.0-124/
· 安装NFP软件包
代码语言:javascript复制 (compute-node)# dpkg -i nfp-bsp-6000-b0*
(compute-node)# ldconfig
· 刷新SmartNIC
代码语言:javascript复制 (compute-node)# /opt/netronome/bin/nfp-flash -P --i-accept-the-risk-of-overwriting-miniloader -w /opt/netronome/flash/flash-nic.bin
(compute-node)# /opt/netronome/bin/nfp-one
(compute-node)# reboot
· 安装核心网卡程序包
代码语言:javascript复制 (compute-node)# cd ns-agilio-vrouter-release_3.1.0.0-124/
(compute-node)# dpkg -i ns-agilio-core-nic*.deb
· 如果您使用的是分支电缆(4×10GbE → 1×40GbE),请更改SmartNIC的media配置。
代码语言:javascript复制 This should create four NFP interfaces: nfp_p0, nfp_p1, nfp_p2, nfp_p3
(compute-node)# /opt/netronome/bin/nfp-media --set-media=phy0=4x10G
(compute-node)# service ns-core-nic.autorun clean
(compute-node)# reboot
· 使用新计算节点的信息填充测试平台
代码语言:javascript复制 (controller-node)# vim /opt/contrail/utils/fabfile/testbeds/testbed.py
bond= {
compute3 : { 'name': 'bond0', 'member': ['nfp_p0','nfp_p1','nfp_p2','nfp_p3'], 'mode': '802.3ad',
'xmit_hash_policy': 'layer3 4' }
}
control_data = {
controller : { 'ip': '172.31.255.1/24', 'gw' : '172.31.255.1', 'device': 'eth1' },
compute3 : { 'ip': '172.31.255.4/24', 'gw' : '172.31.255.1', 'device': 'bond0' }
}
env.ns_agilio_vrouter = {
compute3: {'huge_page_alloc': '24G', 'huge_page_size': '1G', 'coremask': '2,4', 'pinning_mode':
'auto:split'},
}
示例文件请见:https://github.com/savithruml/netronome-agilio-vrouter/tree/3.1.2/testbed
· 安装Tungsten Fabric
代码语言:javascript复制 (controller-node)# cd /opt/contrail/utils
(controller-node)# fab install_pkg_node:/tmp/contrail-install-packages*.deb,root@<new-compute-ip>
(controller-node)# ssh root@<new-compute-ip> "cd /opt/contrail/contrail_packages; ./setup.sh"
(controller-node)# scp /tmp/ns-agilio-vrouter-depends-packages*.deb root@:<new-compute-ip>:/opt/contrail/contrail_install_repo/
(controller-node)# fab install_pkg_node:/tmp/ns-agilio-vrouter-depends-packages*.deb,root@<new-compute-ip>
(controller-node)# ssh root@<new-compute-ip> "cd /opt/contrail/contrail_packages_ns_agilio_vrouter; ./setup.sh"
(controller-node)# ssh root@<new-compute-ip> "cd /opt/contrail/contrail_install_repo; dpkg-scanpackages . /dev/null | gzip -9c > Packages.gz; apt-get update"
(controller-node)# fab add_vrouter_node:root@<new-compute-ip>
(注:文中Contrail以功能一致的Tungsten Fabric替换)