Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Optimieren Sie Ihre EC2 Instance im Hinblick auf die Leistung
Anmerkung
Wenn Sie Ihre AWS Ressourcen mithilfe von CloudFormation Vorlagen bereitgestellt haben, werden diese Optimierungen automatisch angewendet. Wenn Sie eine Instanz verwendet AMI oder Ihre EC2 Instanz manuell erstellt haben, müssen diese Leistungsoptimierungen angewendet werden, um eine möglichst zuverlässige Leistung zu erzielen.
Denken Sie daran, Ihre Instance neu zu starten, nachdem Sie alle Optimierungen vorgenommen haben.
Topics
Optimieren Sie Hardware-Interrupts und Empfangswarteschlangen — Auswirkungen auf CPU das Netzwerk
In diesem Abschnitt wird die CPU grundlegende Verwendung von systemd SMPIRQs, Receive Packet Steering (RPS) und Receive Flow Steering () konfiguriert. RFS Eine Reihe von empfohlenen Einstellungen, die auf dem von Ihnen verwendeten Instanztyp basieren, finden Sie unter. Anhang: Empfohlene Parameter für Interrupt/Tune RPS
-
Platzieren Sie systemd-Prozesse von CPU Agentenkernen fern.
-
Leitet Hardware-Interrupt-Anfragen von den CPU Agentenkernen weg.
-
Konfigurieren Sie RPS die Konfiguration so, dass die Hardwarewarteschlange einer einzelnen Netzwerkschnittstellenkarte nicht zu einem Engpass im Netzwerkverkehr wird.
-
Konfigurieren Sie die KonfigurationRFS, um die CPU Cache-Trefferquote zu erhöhen und dadurch die Netzwerklatenz zu reduzieren.
Das von der bereitgestellte set_irq_affinity.sh
Skript RPM konfiguriert alle oben genannten Funktionen für Sie. Zu crontab hinzufügen, damit es bei jedem Start angewendet wird:
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
Ersetzen Sie es durch Kerne, die für den Kernel und das Betriebssystem reserviert sind — in der Regel den ersten und den zweiten, zusammen mit Hyperthread-Kernpaaren. Dies sollte sich nicht mit den oben ausgewählten Kernen überschneiden. (Beispiel: '0,1,48,49' für eine 96-Instance mit Hyper-Threading). CPU -
rps_core_mask
ist eine hexadezimale Bitmaske, die angibt, welche eingehenden Pakete verarbeitet werden CPUs sollen, wobei jede Ziffer für 4 steht. CPUs Sie muss außerdem alle 8 Zeichen, beginnend von rechts, durch Kommas getrennt werden. Es wird empfohlen, alles zuzulassen CPUs und das Balancing vom Caching übernehmen zu lassen.-
Eine Liste der empfohlenen Parameter für jeden Instance-Typ finden Sie Anhang: Empfohlene Parameter für Interrupt/Tune RPS unter.
-
-
Beispiel für eine CPU 96-Instanz:
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 Interrupt Coalescing — wirkt sich auf das Netzwerk aus
Interrupt-Coalescing verhindert, dass das Host-System mit zu vielen Interrupts überflutet wird, und erhöht den Netzwerkdurchsatz. Bei dieser Konfiguration werden Pakete gesammelt und alle 128 Mikrosekunden ein einziger Interrupt generiert. Zu crontab hinzufügen, sodass es bei jedem Start angewendet wird:
echo "@reboot sudo ethtool -C ${interface} rx-usecs 128 tx-usecs 128 >>/var/log/user-data.log 2>&1" >>/var/spool/cron/root
-
interface
Ersetzen Sie es durch die Netzwerkschnittstelle (Ethernet-Adapter), die für den Empfang von Daten konfiguriert ist. In der Regel ist dies der Fall,eth0
da dies die Standard-Netzwerkschnittstelle ist, die einer EC2 Instanz zugewiesen wurde.
Tune Rx Ring Buffer — wirkt sich auf das Netzwerk aus
Erhöhen Sie die Anzahl der Ringeinträge für den Rx-Ringpuffer, um Paketverluste oder -überläufe bei Burst-Verbindungen zu verhindern. Fügen Sie dem Crontab Folgendes hinzu, damit es bei jedem Start korrekt eingestellt ist:
echo "@reboot sudo ethtool -G ${interface} rx 16384 >>/var/log/user-data.log 2>&1" >>/var/spool/cron/root
-
interface
Ersetzen Sie es durch die Netzwerkschnittstelle (Ethernet-Adapter), die für den Empfang von Daten konfiguriert ist. In der Regel ist dies der Fall,eth0
da dies die Standard-Netzwerkschnittstelle ist, die einer EC2 Instanz zugewiesen wurde. -
Wenn Sie eine c6i.32xlarge-Instance einrichten, muss der Befehl so geändert werden, dass der Ringpuffer auf statt auf gesetzt wird.
8192
16384
Tune C-State — Auswirkungen CPU CPU
Stellen Sie den CPU C-State ein, um Leerlauf zu verhindern, der zu Paketverlusten beim Start eines Kontakts führen kann. Erfordert einen Neustart der Instanz.
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
Eingangsports reservieren — wirkt sich auf das Netzwerk aus
Reservieren Sie alle Ports in Ihrem AwsGroundStationAgentEndpoint
Eingangsadress-Portbereich, um Konflikte bei der Kernel-Nutzung zu vermeiden. Ein Konflikt bei der Portnutzung führt dazu, dass der Kontakt und die Datenübermittlung fehlschlagen.
echo "net.ipv4.ip_local_reserved_ports=${port_range_min}-${port_range_max}" >> /etc/sysctl.conf
-
Beispiel:
echo "net.ipv4.ip_local_reserved_ports=42000-43500" >> /etc/sysctl.conf
.
Neustart
Nachdem alle Optimierungen erfolgreich angewendet wurden, starten Sie die Instanz neu, damit die Optimierungen wirksam werden.
sudo reboot
Anhang: Empfohlene Parameter für Interrupt/Tune RPS
In diesem Abschnitt werden die empfohlenen Parameterwerte für die Verwendung im Tuning-Abschnitt Tune Hardware Interrupts and Receive Queues — Impacts and Network festgelegt. CPU
Familie | Instance-Typ | $ {interrupt_core_list} | $ {rps_core_mask} |
---|---|---|---|
c6i |
|
|
|
c5 |
|
|
|
c5n |
|
|
|
m5 |
|
|
|
r5 |
|
|
|
r5n |
|
|
|
g4dn |
|
|
|
p4d |
|
|
|
p3dn |
|
|
|