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.
Verwenden der Paginierungsoptionen in der AWS CLI
In diesem Thema werden die verschiedenen Möglichkeiten beschrieben, die Ausgabe der AWS CLI zu paginieren.
Es gibt hauptsächlich zwei Möglichkeiten, die Paginierung vom AWS CLI aus zu steuern.
Serverseitige Paginierungsparameter werden zuerst verarbeitet und jede Ausgabe wird an die clientseitige Paginierung gesendet.
Serverseitige Paginierung
Bei Befehlen, die eine große Liste von Elementen zurückgeben können, bietet AWS Command Line Interface (AWS CLI) mehrere Optionen, um die Anzahl der Elemente zu steuern, die in der Ausgabe enthalten sind, wenn der API Dienst die Liste AWS CLI auffüllt.
Es gibt die folgenden Optionen:
Standardmäßig AWS CLI verwendet der eine Seitengröße, die vom jeweiligen Dienst bestimmt wird, und ruft alle verfügbaren Elemente ab. Amazon S3 hat beispielsweise eine Standardseitengröße von 1 000. Wenn Sie aws
s3api list-objects
auf einem Amazon-S3-Bucket ausführen, der 3 500 Objekte enthält, ruft die AWS CLI
Amazon S3 automatisch vier Mal auf, verarbeitet die servicespezifische Paginierungslogik für Sie im Hintergrund und gibt alle 3 500 Objekte in der endgültigen Ausgabe zurück.
So verwenden Sie den --no-paginate-Parameter
Die --no-paginate
-Option deaktiviert folgende Paginierungs-Token auf der Client-Seite. Wenn Sie einen Befehl verwenden, führt der standardmäßig AWS CLI automatisch mehrere Aufrufe durch, um alle möglichen Ergebnisse zurückzugeben und eine Seitennummerierung zu erstellen. Ein Aufruf für jede Seite. Beim Deaktivieren der Paginierung wird die erste Seite mit Befehlsergebnissen AWS CLI nur einmal aufgerufen.
Wenn Sie beispielsweise einen aws s3api list-objects
Amazon S3-Bucket verwenden, der 3.500 Objekte enthält, ruft der Amazon S3 AWS CLI nur zum ersten Mal auf und gibt in der endgültigen Ausgabe nur die ersten 1.000 Objekte zurück.
$
aws s3api list-objects \ --bucket amzn-s3-demo-bucket \
--no-paginate
{ "Contents": [ ...
So verwenden Sie den –page-size-Parameter
Wenn beim Ausführen von Listenbefehlen für eine große Anzahl von Ressourcen Probleme auftreten, ist die Standardseitengröße möglicherweise zu hoch. Dies kann dazu führen, dass Aufrufe von AWS Diensten die maximal zulässige Zeit überschreiten und zu einem „Timeout“ -Fehler führen. Sie können die --page-size
Option verwenden, um anzugeben, dass bei jedem Aufruf des AWS Dienstes eine geringere Anzahl von Elementen AWS CLI angefordert wird. Der ruft AWS CLI immer noch die vollständige Liste ab, führt jedoch eine größere Anzahl von API Serviceaufrufen im Hintergrund durch und ruft bei jedem Aufruf eine geringere Anzahl von Elementen ab. Dadurch ist es wahrscheinlicher, dass Aufrufe nicht zu einem Zeitüberschreitungsfehler führen. Eine Änderung der Seitengröße wirkt sich nicht auf die Ausgabe aus, sondern nur auf die Anzahl der API Aufrufe, die zur Generierung der Ausgabe erforderlich sind.
$
aws s3api list-objects \ --bucket amzn-s3-demo-bucket \
--page-size 100
{ "Contents": [ ...
So verwenden Sie den –max-items-Parameter
Verwenden Sie die --max-items
Option, um weniger Elemente gleichzeitig in die AWS CLI Ausgabe aufzunehmen. Der verarbeitet die Seitennummerierung mit dem Service AWS CLI weiterhin wie zuvor beschrieben, druckt aber nur die Anzahl der Elemente gleichzeitig aus, die Sie angeben.
$
aws s3api list-objects \ --bucket amzn-s3-demo-bucket \ --max-items 100
{ "NextToken": "eyJNYXJrZXIiOiBudWxsLCAiYm90b190cnVuY2F0ZV9hbW91bnQiOiAxfQ==", "Contents": [ ...
So verwenden Sie den –starting-token-Parameter
Wenn die Anzahl der Output (--max-items
) -Elemente geringer ist als die Gesamtzahl der von den zugrunde liegenden API Aufrufen zurückgegebenen Elemente, enthält die Ausgabe eine, NextToken
die Sie an einen nachfolgenden Befehl übergeben können, um die nächste Gruppe von Elementen abzurufen. Im folgenden Beispiel wird gezeigt, wie Sie den Wert NextToken
aus dem vorherigen Beispiel verwenden und die zweiten hundert Elemente abrufen.
Anmerkung
Der Parameter --starting-token
kann nicht null oder leer sein. Wenn der vorherige Befehl keinen NextToken
-Wert zurückgibt, können keine weiteren Elemente zurückgegeben werden und Sie müssen den Befehl nicht erneut aufrufen.
$
aws s3api list-objects \ --bucket amzn-s3-demo-bucket \ --max-items 100 \
--starting-token eyJNYXJrZXIiOiBudWxsLCAiYm90b190cnVuY2F0ZV9hbW91bnQiOiAxfQ==
{ "Contents": [ ...
Der angegebene AWS Dienst gibt möglicherweise nicht bei jedem Aufruf Elemente in derselben Reihenfolge zurück. Wenn Sie verschiedene Werte für --page-size
und --max-items
angeben, können Sie unerwartete Ergebnisse mit fehlenden oder doppelten Elementen bekommen. Um dies zu verhindern, verwenden Sie dieselbe Zahl für --page-size
und --max-items
, um die Paginierung der AWS CLI
mit der Paginierung der zugrunde liegenden Services zu synchronisieren. Sie können auch die gesamte Liste abrufen und erforderliche Paginierungsvorgänge lokal durchführen.
Clientseitiger Pager
AWS CLI Version 2 bietet die Verwendung eines clientseitigen Pager-Programms für die Ausgabe. Standardmäßig gibt diese Funktion alle Ausgaben über das Standard-Pager-Programm Ihres Betriebssystems zurück.
In der Reihenfolge der Rangfolge können Sie den Ausgabe-Pager wie folgt angeben:
-
Verwenden der Einstellung
cli_pager
in der Dateiconfig
imdefault
oder einem benannten Profil. -
Über die
AWS_PAGER
Umgebungsvariable. -
Über die
PAGER
Umgebungsvariable.
In der Rangfolge können Sie die Verwendung eines externen Paging-Programms auf folgende Weise deaktivieren:
-
Verwenden Sie die
--no-cli-pager
-Befehlszeilenoption, um den Pager für eine einzelne Befehlsverwendung zu deaktivieren. -
Setzen Sie die Einstellung
cli_pager
oder VariableAWS_PAGER
auf eine leere Zeichenfolge.
Themen zu clientseitigem Pager:
So verwenden Sie die cli_pager-Einstellung
Sie können Ihre häufig verwendeten Konfigurationseinstellungen und Anmeldeinformationen in Dateien speichern, die von der AWS CLI verwaltet werden. Einstellungen in einem Namensprofil haben Vorrang vor den Einstellungen im default
-Profil. Weitere Informationen zu den verschiedenen Konfigurationseinstellungen finden Sie unter Einstellungen für die Konfiguration und die Anmeldeinformationsdatei in der AWS CLI.
Im folgenden Beispiel wird der Standard-Ausgabe-Pager auf das less
-Programm eingestellt.
[default] cli_pager=less
Im folgenden Beispiel wird die Standardeinstellung zur Deaktivierung der Verwendung eines Pagers festgelegt.
[default] cli_pager=
Wie legt man die Umgebungsvariable fest AWS_PAGER
Im folgenden Beispiel wird der Standard-Ausgabe-Pager auf das less
-Programm eingestellt. Weitere Informationen zu Umgebungsvariablen finden Sie unter Konfiguration von Umgebungsvariablen für AWS CLI.
Wie benutzt man die no-cli-pager Option --
Um die Verwendung eines Pagers für einen einzelnen Befehl zu deaktivieren, verwenden Sie die Option --no-cli-pager
. Weitere Informationen zu diesen Befehlszeilenoptionen finden Sie unter Befehlszeilenoptionen in der AWS CLI.
$
aws s3api list-objects \ --bucket amzn-s3-demo-bucket \
--no-cli-pager
{ "Contents": [ ...
So verwenden Sie Pager-Flags
Sie können Flags angeben, die automatisch mit Ihrem Paging-Programm verwendet werden sollen. Flags sind abhängig von dem Paging-Programm, das Sie verwenden. Die folgenden Beispiele beziehen sich auf die typischen Standardwerte von less
und more
.