調整EC2執行個體的效能 - AWS Ground Station

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

調整EC2執行個體的效能

注意

如果您使用 CloudFormation 範本佈建AWS資源,這些調校會自動套用。如果您使用 AMI或 手動建立EC2執行個體,則必須套用這些效能調校,才能實現最可靠的效能。

請記得在套用任何調校後重新啟動執行個體 (這些調整)。

主題

調整硬體中斷和接收佇列 - 影響CPU和網路

本節設定系統化、IRQs、接收封包指導 (RPS) SMP 和接收流程指導 () CPU的核心用量RFS。如需根據您使用的執行個體類型建議的設定集,附錄:中斷/RPS調校的建議參數請參閱 。

  1. 將系統化程序釘選為遠離代理程式CPU核心。

  2. 將硬體中斷請求路由到遠離代理程式CPU核心的位置。

  3. 設定 RPS以防止單一網路介面卡的硬體佇列成為網路流量的瓶頸。

  4. 設定 RFS 以增加CPU快取命中率,進而降低網路延遲。

提供的set_irq_affinity.sh指令碼會為您RPM設定上述所有項目。新增至 crontab,因此會套用至每個開機:

echo "@reboot sudo /opt/aws/groundstation/bin/set_irq_affinity.sh '${interrupt_core_list}' '${rps_core_mask}' >> /var/log/user-data.log 2>&1" >>/var/spool/cron/root
  • interrupt_core_list 以為核心和作業系統預留的核心取代 - 通常為第一和第二核心,以及超執行緒核心對。這不應與上述選取的核心重疊。(例如,超執行緒 96 個CPU執行個體為「0,1,48,49」)。

  • rps_core_mask 是十六進位位元遮罩,指定CPUs哪些應該處理傳入封包,每個數字代表 4 CPUs。也必須從右側開始,以逗號分隔每 8 個字元。建議允許所有 CPUs,並讓快取處理平衡。

  • 96 CPU執行個體的範例:

    echo "@reboot sudo /opt/aws/groundstation/bin/set_irq_affinity.sh '0,1,48,49' 'ffffffff,ffffffff,ffffffff' >> /var/log/user-data.log 2>&1" >>/var/spool/cron/root

Tune Rx 中斷合作 - 影響網路

中斷協同合作有助於防止主機系統因太多中斷而溢出,並有助於提高網路輸送量。透過此組態,會收集封包,並每 128 微秒產生一次中斷。新增至 crontab,因此會套用至每個開機:

echo "@reboot sudo ethtool -C ${interface} rx-usecs 128 tx-usecs 128 >>/var/log/user-data.log 2>&1" >>/var/spool/cron/root
  • interface 以設定為接收資料的網路介面 (乙太網路轉接器) 取代 。一般而言,eth0這是為EC2執行個體指派的預設網路介面。

Tune Rx 環形緩衝區 - 影響網路

增加 Rx 環狀緩衝區的環狀項目數量,以防止封包在繁重的連線期間遭到捨棄或超支。新增至 crontab,以便在每次開機時正確設定:

echo "@reboot sudo ethtool -G ${interface} rx 16384 >>/var/log/user-data.log 2>&1" >>/var/spool/cron/root
  • interface 以設定為接收資料的網路介面 (乙太網路轉接器) 取代 。一般而言,eth0這是為EC2執行個體指派的預設網路介面。

  • 如果設定 c6i.32xlarge 執行個體,則需要修改命令,將環形緩衝區設定為 8192,而不是 16384

調校 CPU C 狀態 - 影響 CPU

設定 CPU C 狀態以防止閒置,這可能會導致聯絡人開始時遺失封包。需要重新啟動執行個體。

echo "GRUB_CMDLINE_LINUX_DEFAULT=\"console=tty0 console=ttyS0,115200n8 net.ifnames=0 biosdevname=0 nvme_core.io_timeout=4294967295 intel_idle.max_cstate=1 processor.max_cstate=1 max_cstate=1\"" >/etc/default/grub echo "GRUB_TIMEOUT=0" >>/etc/default/grub grub2-mkconfig -o /boot/grub2/grub.cfg

預留輸入連接埠 - 影響網路

保留 AwsGroundStationAgentEndpoint輸入地址連接埠範圍內的所有連接埠,以防止與核心使用發生衝突。連接埠使用衝突會導致聯絡和資料交付失敗。

echo "net.ipv4.ip_local_reserved_ports=${port_range_min}-${port_range_max}" >> /etc/sysctl.conf
  • 範例:echo "net.ipv4.ip_local_reserved_ports=42000-43500" >> /etc/sysctl.conf

重新開機

成功套用所有調校後,重新啟動執行個體,讓調校生效。

sudo reboot

本節決定調整區段 Tune Hardware Interrupts 和 Receive Queues - Impacts CPU和 Network 中使用的建議參數值。

系列 執行個體類型 ${interrupt_core_list} ${rps_core_mask}

c6i

  • c6i.32xlarge

  • 0、1、64、65

  • ffffffff、ffffffff、ffffffff、ffffffff

c5

  • c5.24xlarge

  • c5.18xlarge

  • c5.12xlarge

  • 0、1、48、49

  • 0、1、36、37

  • 0、1、24、25

  • ffffffff、ffffffff、ffffffff

  • ff、ffffffff、ffffffff

  • ffff、ffffffffff

c5n

  • c5n.metal

  • c5n.18xlarge

  • 0、1、36、37

  • 0、1、36、37

  • ff、ffffffff、ffffffff

  • ff、ffffffff、ffffffff

m5

  • m5.24xlarge

  • m5.12xlarge

  • 0、1、48、49

  • 0、1、24、25

  • ffffffff、ffffffff、ffffffff

  • ffff、ffffffffff

r5

  • r5.metal

  • r5.24xlarge

  • 0、1、48、49

  • 0、1、48、49

  • ffffffff、ffffffff、ffffffff

  • ffffffff、ffffffff、ffffffff

r5n

  • r5n.metal

  • r5n.24xlarge

  • 0、1、48、49

  • 0、1、48、49

  • ffffffff、ffffffff、ffffffff

  • ffffffff、ffffffff、ffffffff

g4dn

  • g4dn.metal

  • g4dn.16xlarge

  • g4dn.12xlarge

  • 0、1、48、49

  • 0、1、32、33

  • 0、1、24、25

  • ffffffff、ffffffff、ffffffff

  • ffffffff、ffffffff

  • ffff、ffffffffff

p4d

  • p4d.24xlarge

  • 0、1、48、49

  • ffffffff、ffffffff、ffffffff

p3dn

  • p3dn.24xlarge

  • 0、1、48、49

  • ffffffff、ffffffff、ffffffff