5.2. PCI パススルー用コンピュートノードの設定
クラウドユーザーが PCI デバイスがアタッチされたインスタンスを作成できるようにするには、PCI デバイスを持つコンピュートノードとコントローラーノードの両方を設定する必要があります。
手順
-
PCI パススルー用にオーバークラウド上のコントローラーノードを設定するには、環境ファイル (例:
pci_passthru_controller.yaml) を作成します。 pci_passthrough_controller.yamlのNovaSchedulerDefaultFiltersパラメーターにPciPassthroughFilterを追加します。parameter_defaults: NovaSchedulerDefaultFilters: ['AvailabilityZoneFilter','ComputeFilter','ComputeCapabilitiesFilter','ImagePropertiesFilter','ServerGroupAntiAffinityFilter','ServerGroupAffinityFilter','PciPassthroughFilter','NUMATopologyFilter']
parameter_defaults: NovaSchedulerDefaultFilters: ['AvailabilityZoneFilter','ComputeFilter','ComputeCapabilitiesFilter','ImagePropertiesFilter','ServerGroupAntiAffinityFilter','ServerGroupAffinityFilter','PciPassthroughFilter','NUMATopologyFilter']Copy to Clipboard Copied! Toggle word wrap Toggle overflow コントローラーノード上のデバイスの PCI エイリアスを指定するには、以下の設定を
pci_passthrough_controller.yamlに追加します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow device_typeフィールドの設定に関する詳細は、PCI パススルーデバイス種別フィールド を参照してください。注記nova-apiサービスがController以外のロールで実行されている場合は、ControllerExtraConfigを<Role>ExtraConfigの形式でユーザーロールに置き換えます。(オプション): PCI パススルーデバイスにデフォルトの NUMA アフィニティーポリシーを設定するには、ステップ 3 の
numa_policy設定にnova::pci::aliases:を追加します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
PCI パススルー用にオーバークラウド上のコンピュートノードを設定するには、環境ファイル (例:
pci_passthrough_compute.yaml) を作成します。 コンピュートノード上のデバイスの利用可能な PCI を指定するには、
vendor_idおよびproduct_idオプションを使用して、インスタンスへのパススルーに使用できる PCI デバイスのプールに、一致するすべての PCI デバイスを追加します。たとえば、すべての Intel® Ethernet Controller X710 デバイスをインスタンスへのパススルーに使用できる PCI デバイスのプールに追加するには、以下の設定をpci_passthrough_compute.yamlに追加します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow NovaPCIPassthroughの設定方法の詳細は、NovaPCIPassthrough設定のガイドライン を参照してください。インスタンスの移行およびサイズ変更の操作を行うために、コンピュートノードの PCI エイリアスのコピーを作成する必要があります。PCI パススルー用コンピュートノード上のデバイスの PCI エイリアスを指定するには、以下の設定を
pci_passthrough_compute.yamlに追加します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow 注記コンピュートノードのエイリアスは、コントローラーノードのエイリアスと同じでなければなりません。したがって、
pci_passthrough_controller.yamlのnova::pci::aliasesにnuma_affinityを追加した場合は、pci_passthrough_compute.yamlのnova::pci::aliasesにも追加する必要があります。PCI パススルーをサポートするためにコンピュートノードのサーバー BIOS で IOMMU を有効にするには、
pci_passthrough_compute.yamlにKernelArgsパラメーターを追加します。たとえば、Intel IOMMU を有効にするには、以下のKernalArgs設定を使用します。parameter_defaults: ... ComputePCIParameters: KernelArgs: "intel_iommu=on iommu=pt"parameter_defaults: ... ComputePCIParameters: KernelArgs: "intel_iommu=on iommu=pt"Copy to Clipboard Copied! Toggle word wrap Toggle overflow AMD IOMMU を有効にするには、
KernelArgsを"amd_iommu=on iommu=pt"に設定します。その他の環境ファイルと共にこれらのカスタム環境ファイルをスタックに追加して、オーバークラウドをデプロイします。
openstack overcloud deploy --templates \ -e [your environment files] \ -e /home/stack/templates/pci_passthrough_controller.yaml \ -e /home/stack/templates/pci_passthrough_compute.yaml \
(undercloud)$ openstack overcloud deploy --templates \ -e [your environment files] \ -e /home/stack/templates/pci_passthrough_controller.yaml \ -e /home/stack/templates/pci_passthrough_compute.yaml \Copy to Clipboard Copied! Toggle word wrap Toggle overflow クラウドユーザーが PCI デバイスを要求するのに使用できるフレーバーを作成および設定します。以下の例では、ステップ 7 で定義したエイリアスを使用して、それぞれベンダー ID および製品 ID が
8086および1572の 2 つのデバイスを要求します。openstack flavor set \ --property "pci_passthrough:alias"="a1:2" device_passthrough
(overcloud)# openstack flavor set \ --property "pci_passthrough:alias"="a1:2" device_passthroughCopy to Clipboard Copied! Toggle word wrap Toggle overflow (オプション) フレーバーまたはイメージに NUMA アフィニティーポリシーの属性キーを追加して、PCI パススルーデバイスのデフォルト NUMA アフィニティーポリシーをオーバーライドすることができます。
フレーバーを使用してデフォルトの NUMA アフィニティーポリシーをオーバーライドするには、
hw:pci_numa_affinity_policy属性キーを追加します。openstack flavor set \ --property "hw:pci_numa_affinity_policy"="required" \ device_passthrough
(overcloud)# openstack flavor set \ --property "hw:pci_numa_affinity_policy"="required" \ device_passthroughCopy to Clipboard Copied! Toggle word wrap Toggle overflow hw:pci_numa_affinity_policyの有効な値についての詳しい情報は、フレーバーのメタデータ を参照してください。イメージを使用してデフォルトの NUMA アフィニティーポリシーをオーバーライドするには、
hw_pci_numa_affinity_policy属性キーを追加します。openstack image set \ --property hw_pci_numa_affinity_policy=required \ device_passthrough_image
(overcloud)# openstack image set \ --property hw_pci_numa_affinity_policy=required \ device_passthrough_imageCopy to Clipboard Copied! Toggle word wrap Toggle overflow 注記イメージとフレーバーの両方で NUMA アフィニティーポリシーを設定する場合には、属性の値が一致している必要があります。フレーバーの設定は、イメージおよびデフォルトの設定よりも優先されます。したがって、イメージの NUMA アフィニティーポリシーの設定は、フレーバーで属性が設定されていない場合に限り効果を持ちます。
検証
PCI パススルーデバイスを設定してインスタンスを作成します。
openstack server create --flavor device_passthrough \ --image <image> --wait test-pci
# openstack server create --flavor device_passthrough \ --image <image> --wait test-pciCopy to Clipboard Copied! Toggle word wrap Toggle overflow - クラウドユーザーとしてインスタンスにログインします。詳細は、Connecting to an instance を参照してください。
インスタンスが PCI デバイスにアクセスできることを確認するには、インスタンスから以下のコマンドを入力します。
lspci -nn | grep <device_name>
$ lspci -nn | grep <device_name>Copy to Clipboard Copied! Toggle word wrap Toggle overflow