本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
調整EC2執行個體的效能
注意
如果您使用 CloudFormation 範本佈建AWS資源,這些調校會自動套用。如果您使用 AMI或 手動建立EC2執行個體,則必須套用這些效能調校,才能實現最可靠的效能。
請記得在套用任何調校後重新啟動執行個體 (這些調整)。
主題
調整硬體中斷和接收佇列 - 影響CPU和網路
本節設定系統化、IRQs、接收封包指導 (RPS) SMP 和接收流程指導 () CPU的核心用量RFS。如需根據您使用的執行個體類型建議的設定集,附錄:中斷/RPS調校的建議參數請參閱 。
-
將系統化程序釘選為遠離代理程式CPU核心。
-
將硬體中斷請求路由到遠離代理程式CPU核心的位置。
-
設定 RPS以防止單一網路介面卡的硬體佇列成為網路流量的瓶頸。
-
設定 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,並讓快取處理平衡。-
若要查看每個執行個體類型的建議參數清單,請參閱 附錄:中斷/RPS調校的建議參數。
-
-
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
附錄:中斷/RPS調校的建議參數
本節決定調整區段 Tune Hardware Interrupts 和 Receive Queues - Impacts CPU和 Network 中使用的建議參數值。
系列 | 執行個體類型 | ${interrupt_core_list} | ${rps_core_mask} |
---|---|---|---|
c6i |
|
|
|
c5 |
|
|
|
c5n |
|
|
|
m5 |
|
|
|
r5 |
|
|
|
r5n |
|
|
|
g4dn |
|
|
|
p4d |
|
|
|
p3dn |
|
|
|