フルCPUのパーティショニングと分離によるDPDK vRouterのパフォーマンスの最適化
Contrail Networking リリース 2003 では、フル CPU パーティショニングがサポートされています。CPU 分離は、コンピューティング ノード上の CPU コアをパーティション分割し、対称型マルチプロセッシング (SMP) バランシングおよびスケジューラ アルゴリズムから分離する RHEL メソッドです。完全な CPU 分離機能により、RHOSP に推奨される DPDK 設定で展開された場合に、DPDK vRouter のパフォーマンスが最適化されます。
CPU の分離により、転送コア、VNF コア、サービス コアを分離し、VNF スレッドとサービス スレッドが転送コアに処理要求を送信しないようにすることができます。CPU 分離を適用することで、専用の転送コアを DPDK VM に割り当て、DPDK vRouter に割り当てられたコアに他のプロセスが処理要求を送信しないようにすることで、vRouter のパフォーマンスが大幅に向上します。
CPU の分離とパーティション分割については、RedHat では 2 つの方法を推奨しています。1 つ目の方法は、 と呼ばれる tuned
ユーティリティを使用して、CPU を仮想ネットワーク機能(VNF)にパーティション分割し、これらのコアをホスト OS から分離する方法です。このメソッドは tuned
、プロセスを使用して systemd
、すべてのタスクを処理し、システムの起動後に CPU の分離を実行するために使用される共通 CPU の一覧から分離された CPU を削除します。
2つ目は isolcpus
、CPUをLinuxスケジューラから遠ざけるカーネルパラメータです。と同様に tuned
、このメソッドは isolcpus
、すべてのタスクの処理に使用される共通 CPU リストから分離された CPU を削除し、システムの起動時に CPU の分離を実行します。を有効にするには isolcpus
、/ etc/default/grub の GRUB 設定を変更して、分離された CPU の新しいセットが考慮されるようにする必要があります。変更を有効にするには、ノードを再起動する必要があります。
を使用して tuned
CPU の分離を有効にするには、RHOSP の場合は /tripleo-heat-templates/environments/contrail/contrail-services.yaml 内 をDPDK_CTRL_THREAD_MASK
、SERVICE_CORE_MASK
Contrail Ansible Deployer の場合は /vrouter/agent-dpdk/entrypoint.sh ファイルの および パラメーターを設定しますContrailDpdkParameters
。
In contrail-services.yaml
# Tuned-d profile configuration # TunedProfileName - Name of tuned profile # IsolCpusList - Logical CPUs list to be isolated from the host process (applied via cpu-partitioning tuned). # It is mandatory to provide isolated cpus for tuned to achive optimal performance. # Example: "3-8,12-15,18" # These paramters are to be set per a role, e.g.: # ComputeParameters: # TunedProfileName: "cpu-partitioning" # IsolCpusList: "3-8,12-15,20" # ContrailDpdkParameters: # TunedProfileName: "cpu-partitioning" # IsolCpusList: "3-20" # ContrailSriovParameters: # TunedProfileName: "cpu-partitioning" # IsolCpusList: "3-20"
entrypoint.sh 年
# Cpu coremask for DPDK # - forwarding threads pinning #CPU_CORE_MASK='0x01' # - service threads pinning #SERVICE_CORE_MASK='' # - dpdk ctrl threads pinning #DPDK_CTRL_THREAD_MASK=''
設定 isolcpus
するには、GRUB で以下のパラメータを変更します。
ContrailDpdkParameters: KernelArgs: "default_hugepagesz=1GB hugepagesz=1G hugepages=32 iommu=pt intel_iommu=on isolcpus=3-20"
チューニングは isolcpu
、VNF(VM)に対しても行う必要があります。これは、VM がポーリング モード ドライバー (PMD) スレッド コアを保護し、他のプロセスによる CPU 使用率から分離できるようにするためです。Centos および RHEL では、CPU のチューニングはユーティリティ isolcpu
と tuned
を使用して行われます。