第 5 章 配置 PCI 透传
您可以使用 PCI 透传将物理 PCI 设备(如图形卡或网络设备)附加到实例。如果您将 PCI 透传用于设备,实例会保留对执行任务的设备的专用访问权限,且设备对主机不可用。
将 PCI 透传与路由供应商网络搭配使用
计算服务不支持跨越多个提供商网络的单一网络。当网络包含多个物理网络时,计算服务仅使用第一个物理网络。因此,如果您使用路由的供应商网络,则必须在所有 Compute 节点间使用相同的 physical_network 名称。
如果您将路由供应商网络与 VLAN 或扁平网络一起使用,则必须在所有片段中使用相同的 physical_network 名称。然后,为网络创建多个片段,并将片段映射到适当的子网。
要让您的云用户创建附加 PCI 设备的实例,您必须完成以下操作:
- 为 PCI 透传指定 Compute 节点。
- 为具有所需 PCI 设备的 PCI 透传配置 Compute 节点。
- 部署 overcloud。
- 创建用于启动附加 PCI 设备的实例的类别。
先决条件
- Compute 节点具有所需的 PCI 设备。
5.1. 为 PCI 透传设计 Compute 节点 复制链接链接已复制到粘贴板!
要为附加物理 PCI 设备的实例指定 Compute 节点,您必须创建一个新角色文件来配置 PCI 透传角色,并使用 PCI 透传资源类配置裸机节点,以标记 PCI 透传的 Compute 节点。
以下流程适用于尚未调配的新 overcloud 节点。要将资源类分配给已置备的现有 overcloud 节点,您必须使用 scale down 过程取消置备节点,然后使用扩展过程使用新的资源类分配来重新置备节点。有关更多信息,请参阅 扩展 overcloud 节点。
流程
-
以
stack用户的身份登录 undercloud。 Source
stackrc文件:[stack@director ~]$ source ~/stackrc生成一个名为
roles_data_pci_passthrough.yaml的新角色数据文件,其中包含Controller、Compute和ComputePCI角色,以及 overcloud 所需的任何其他角色:(undercloud)$ openstack overcloud roles \ generate -o /home/stack/templates/roles_data_pci_passthrough.yaml \ Compute:ComputePCI Compute Controller打开
roles_data_pci_passthrough.yaml,并编辑或添加以下参数和部分:Expand section/Parameter 当前值 新值 角色评论
Role: ComputeRole: ComputePCI角色名称
名称 :Compute名称 :ComputePCIdescription基本 Compute 节点角色PCI Passthrough Compute 节点角色HostnameFormatDefault%stackname%-novacompute-%index%%stackname%-novacomputepci-%index%deprecated_nic_config_namecompute.yamlcompute-pci-passthrough.yaml-
将 overcloud 的 PCI 透传 Compute 节点添加到节点定义模板
node.json或node.yaml中,为 overcloud 注册它们。有关更多信息,请参阅 Director 安装和使用 指南中的 为 overcloud 注册节点。 检查节点硬件:
(undercloud)$ openstack overcloud node introspect \ --all-manageable --provide如需更多信息,请参阅 Director 安装和使用指南中的 创建裸机节点硬件清单。
使用自定义 PCI 透传资源类标记您要为 PCI 透传指定的每个裸机节点:
(undercloud)$ openstack baremetal node set \ --resource-class baremetal.PCI-PASSTHROUGH <node>将
<node>替换为裸机节点的 ID。将
ComputePCI角色添加到节点定义文件overcloud-baremetal-deploy.yaml中,并定义您要分配给节点的任何预先节点放置、资源类、网络拓扑或其他属性:- name: Controller count: 3 - name: Compute count: 3 - name: ComputePCI count: 1 defaults: resource_class: baremetal.PCI-PASSTHROUGH network_config: template: /home/stack/templates/nic-config/myRoleTopology.j21 有关您可以在节点定义文件中配置节点属性的属性的更多信息,请参阅 裸机节点置备属性。如需节点定义文件示例,请参阅 节点定义文件示例。
运行置备命令为您的角色置备新节点:
(undercloud)$ openstack overcloud node provision \ --stack <stack> \ [--network-config \] --output /home/stack/templates/overcloud-baremetal-deployed.yaml \ /home/stack/templates/overcloud-baremetal-deploy.yaml-
将
<stack> 替换为置备裸机节点的堆栈的名称。如果未指定,则默认为overcloud。 -
包含
--network-config可选参数,为cli-overcloud-node-network-config.yamlAnsible playbook 提供网络定义。如果您不使用network_config属性定义网络定义,则使用默认网络定义。
-
将
在单独的终端中监控调配进度。当置备成功后,节点状态会从
available改为active:(undercloud)$ watch openstack baremetal node list如果您没有使用
--network-config 选项运行 provisioning 命令,请在network-environment.yaml文件中配置 <Role>NetworkConfigTemplate参数以指向 NIC 模板文件:parameter_defaults: ComputeNetworkConfigTemplate: /home/stack/templates/nic-configs/compute.j2 ComputePCINetworkConfigTemplate: /home/stack/templates/nic-configs/<pci_passthrough_net_top>.j2 ControllerNetworkConfigTemplate: /home/stack/templates/nic-configs/controller.j2将 <
pci_passthrough_net_top> 替换为包含ComputePCI角色的网络拓扑的文件名称,如compute.yaml以使用默认网络拓扑。