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 ein AMI verwendet oder Ihre EC2 Instance manuell erstellt haben, müssen diese Leistungsoptimierungen angewendet werden, um die zuverlässigste Leistung zu erzielen.
Denken Sie daran, Ihre Instance neu zu starten, nachdem Sie alle Optimierungen vorgenommen haben.
Topics
Optimieren Sie Hardware-Interrupts und Empfangswarteschlangen — das wirkt sich auf CPU und Netzwerk aus
In diesem Abschnitt wird die CPU-Kernnutzung von Systemd, SMP IRQs, Receive Packet Steering (RPS) und Receive Flow Steering (RFS) konfiguriert. Eine Reihe von empfohlenen Einstellungen, die auf dem von Ihnen verwendeten Instanztyp basieren, finden Anhang: Empfohlene Parameter für Interrupt/RPS-Tune Sie unter.
-
Platzieren Sie systemd-Prozesse von den CPU-Kernen der Agenten fern.
-
Leitet Hardware-Interrupt-Anfragen von den CPU-Kernen der Agenten weg.
-
Konfigurieren Sie RPS so, dass die Hardware-Warteschlange einer einzelnen Netzwerkschnittstellenkarte nicht zu einem Engpass im Netzwerkverkehr wird.
-
Konfigurieren Sie RFS, um die CPU-Cache-Trefferquote zu erhöhen und dadurch die Netzwerklatenz zu reduzieren.
Das vom RPM bereitgestellte set_irq_affinity.sh
Skript konfiguriert alle oben genannten Funktionen für Sie. Zu crontab hinzufügen, sodass 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 Hyperthread-Instanz mit 96 CPUs). -
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/RPS-Tune unter.
-
-
Beispiel für eine 96-CPU-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
Familieninstanz einrichten, muss der Befehl so geändert werden, dass der Ringpuffer auf8192
statt auf gesetzt wird16384
.
CPU C-State abstimmen — wirkt sich auf die CPU aus
Stellen Sie den CPU-C-Status ein, um einen 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/RPS-Tune
In diesem Abschnitt werden die empfohlenen Parameterwerte für die Verwendung im Abschnitt Feinabstimmung von Hardware-Interrupts und Empfangswarteschlangen — Auswirkungen auf CPU und Netzwerk festgelegt.
Familie | Instance-Typ | $ {interrupt_core_list} | $ {rps_core_mask} |
---|---|---|---|
c6i |
|
|
|
c5 |
|
|
|
c5n |
|
|
|
m5 |
|
|
|
r5 |
|
|
|
r5n |
|
|
|
g4dn |
|
|
|
p4d |
|
|
|
p3dn |
|
|
|