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.
Verwaltung des Container-Swap-Speicherplatzes bei Amazon ECS
Mit Amazon ECS können Sie die Nutzung von Swap-Speicherplatz auf Ihren Linux-basierten EC2 Amazon-Instances auf Containerebene steuern. Bei der Verwendung einer Auslagerungskonfiguration pro Container kann die Auslagerung für jeden Container innerhalb einer Aufgabendefinition aktiviert oder deaktiviert sein. Für diejenigen, für die sie aktiviert ist, kann die maximale Menge des verwendeten Auslagerungsbereichs begrenzt sein. Beispielsweise kann die Auslagerung bei latenzkritischen Containern deaktiviert sein. Im Gegensatz dazu kann bei Containern mit hohem transienten Speicherbedarf Swap aktiviert sein, um die Wahrscheinlichkeit von out-of-memory Fehlern zu verringern, wenn der Container ausgelastet ist.
Die Auslagerungskonfiguration für einen Container wird mit den folgenden Container-Definitionsparametern verwaltet.
maxSwap
-
Die Gesamtmenge des Auslagerungsspeichers (in MiB), den ein Container verwenden kann. Dieser Parameter wird in die
--memory-swap
Option to Docker Run übersetzt, wobei der Wert die Summe aus dem Container-Speicher plus demmaxSwap
Wert ist.Wenn als
maxSwap
-Wert0
angegeben wird, verwendet der Container keine Auslagerung. Zulässige Werte sind0
oder eine beliebige positive Ganzzahl. Wenn der ParametermaxSwap
weggelassen wird, verwendet der Container die Swap-Konfiguration für die Container-Instance, auf der er ausgeführt wird. Es muss ein Wert fürmaxSwap
festgelegt werden, damit der Parameterswappiness
verwendet werden kann. swappiness
-
Auf diese Weise können Sie das Speicherauslagerungsverhalten eines Containers optimieren. Ein
swappiness
-Wert von0
führt dazu, dass keine Auslagerung stattfindet, es sei denn, dies ist absolut notwendig. Einswappiness
-Wert von100
führt dazu, dass Seiten aggressiv ausgelagert werden. Akzeptierte Werte sind Ganzzahlen zwischen0
und100
. Wenn der Parameterswappiness
nicht angegeben wird, wird der Standardwert60
verwendet. Wenn kein Wert fürmaxSwap
angegeben ist, wird dieser Parameter ignoriert. Dieser Parameter ist der--memory-swappiness
Option docker run zugeordnet.
Im folgenden Beispiel wird die JSON Syntax bereitgestellt.
"containerDefinitions": [{
...
"linuxParameters": {
"maxSwap": integer
,
"swappiness": integer
},
...
}]
Überlegungen
Beachten Sie Folgendes, wenn Sie eine Auslagerungskonfiguration pro Container verwenden.
-
Der Swap-Speicherplatz muss auf der EC2 Amazon-Instance, die Ihre Aufgaben hostet, aktiviert und zugewiesen sein, damit die Container ihn verwenden können. Standardmäßig ist bei den ECS Amazon-Optimierten AMIs kein Swap aktiviert. Sie müssen die Auslagerung auf der Instance aktivieren, um dieses Feature verwenden zu können. Weitere Informationen finden Sie unter Instance Store Swap Volumes im EC2Amazon-Benutzerhandbuch oder unter Wie weise ich Speicher zu, um als Swap-Speicherplatz in einer EC2 Amazon-Instance zu fungieren?
. -
Die Definitionsparameter des Swap-Space-Containers werden nur für Aufgabendefinitionen unterstützt, die den EC2 Starttyp angeben. Diese Parameter werden nicht für Aufgabendefinitionen unterstützt, die nur für die Verwendung durch Amazon ECS on Fargate vorgesehen sind.
-
Dieses Feature wird nur für Linux-Container unterstützt. Windows-Container werden derzeit nicht unterstützt.
-
Wenn die Container-Definitionsparameter
maxSwap
undswappiness
in einer Aufgabendefinition weggelassen werden, hat jeder Container denswappiness
-Standardwert60
. Darüber hinaus ist die gesamte Swap-Nutzung auf das Zweifache des Speichers des Containers begrenzt. -
Wenn Sie Aufgaben auf Amazon Linux 2023 verwenden, wird der
swappiness
-Parameter nicht unterstützt.