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.
HTTPKunden
Sie können den HTTP Client ändern, der für Ihren Service-Client verwendet werden soll, sowie die Standardkonfiguration für HTTP Clients mit dem ändern AWS SDK for Java 2.x. In diesem Abschnitt werden HTTP Clients und Einstellungen für die beschriebenSDK.
HTTPClients, die in der SDK für Java verfügbar sind
Synchrone Clients
Synchrone HTTP Clients in der SDK für Java implementieren die SdkHttpClientS3Client
oder derDynamoDbClient
, erfordert die Verwendung eines synchronen HTTP Clients. Der AWS SDK for Java bietet drei synchrone HTTP Clients.
- ApacheHttpClient (Standard)
-
ApacheHttpClient
ist der HTTP Standardclient für synchrone Dienstclients. Hinweise zur Konfiguration von finden Sie ApacheHttpClient
unterDen HTTP Apache-basierten Client konfigurieren. - AwsCrtHttpClient
-
AwsCrtHttpClient
bietet hohen Durchsatz und blockierungsfreie I/O. Es basiert auf dem AWS Common Runtime (CRT) Http Client. Hinweise zur Konfiguration AwsCrtHttpClient
und Verwendung mit Service-Clients finden Sie unterKonfiguration von AWS CRT basierten HTTP Clients. - UrlConnectionHttpClient
-
Um die Anzahl der von Ihrer Anwendung verwendeten JAR-Dateien und Bibliotheken von Drittanbietern zu minimieren, können Sie die verwenden UrlConnectionHttpClient
. Hinweise zur Konfiguration von finden UrlConnectionHttpClient
Sie unterDen URLConnection basierten HTTP Client konfigurieren.
Asynchrone Clients
Asynchrone HTTP Clients in der SDK für Java implementieren die SdkAsyncHttpClientS3AsyncClient
oder derDynamoDbAsyncClient
, erfordert die Verwendung eines asynchronen HTTP Clients. Der AWS SDK for Java bietet zwei asynchrone HTTP Clients.
- NettyNioAsyncHttpClient (Standard)
-
NettyNioAsyncHttpClient
ist der HTTP Standardclient, der von asynchronen Clients verwendet wird. Hinweise zur Konfiguration von finden Sie NettyNioAsyncHttpClient
unterDen Netty-basierten Client HTTP konfigurieren. - AwsCrtAsyncHttpClient
-
Der AwsCrtAsyncHttpClient
basiert auf dem AWS Common Runtime (CRT) HTTP Client. Hinweise zur Konfiguration von finden AwsCrtAsyncHttpClient
Sie unterKonfiguration von AWS CRT basierten HTTP Clients.
HTTPEmpfehlungen des Kunden
Bei der Auswahl einer HTTP Kundenimplementierung spielen mehrere Faktoren eine Rolle. Verwenden Sie die folgenden Informationen als Entscheidungshilfe.
Flussdiagramm für Empfehlungen
Das folgende Flussdiagramm enthält allgemeine Hinweise, anhand derer Sie entscheiden können, welcher HTTP Client verwendet werden soll.
HTTPKundenvergleich
Die folgende Tabelle enthält detaillierte Informationen für jeden HTTP Kunden.
HTTPKunde | Synchronisieren oder asynchron | Wann sollte dies verwendet werden? | Einschränkung/Nachteil |
---|---|---|---|
Apache-basierter Client HTTP (Standard-Synchronisierungsclient) HTTP |
Synchronisierung | Verwenden Sie ihn, wenn Sie eine niedrige Latenz einem hohen Durchsatz vorziehen | Langsamere Startzeit im Vergleich zu anderen HTTP Clients |
URLConnectionbasierter HTTP Client | Synchronisierung | Verwenden Sie ihn, wenn Sie unbedingt die Abhängigkeiten von Drittanbietern einschränken möchten | Unterstützt die HTTP PATCH Methode nicht, die für einige Operationen APIS wie Amazon APIGateway Update erforderlich ist |
AWS CRTbasierter HTTP Synchronisierungsclient 1 | Synchronisierung |
• Verwenden Sie es, wenn Ihre Anwendung in läuft AWS Lambda • Verwenden Sie es, wenn Sie einen hohen Durchsatz einer niedrigen Latenz vorziehen • Verwenden Sie es, wenn Sie SDK Synchronisierungsclients bevorzugen |
Die folgenden Java-Systemeigenschaften werden nicht unterstützt:
|
Netty-basierter Client HTTP (standardmäßiger HTTP asynchroner Client) |
Asynchron |
• Verwenden Sie es, wenn Ihre Anwendung Aufrufe erfordertAPIs, die HTTP /2-Unterstützung erfordern, z. B. Kinesis API SubscribeToShard |
Langsamere Startzeit im Vergleich zu anderen Clients HTTP |
AWS CRTbasierter asynchroner HTTP Client 1 | Asynchron | • Verwenden Sie es, wenn Ihre Anwendung läuft in AWS Lambda • Verwenden Sie es, wenn Sie einen hohen Durchsatz einer niedrigen Latenz vorziehen • Verwenden Sie es, wenn Sie asynchrone Clients SDK bevorzugen |
• Unterstützt keine Service-Clients, die HTTP /2-Unterstützung benötigen, wie und Die folgenden Java-Systemeigenschaften werden nicht unterstützt:
|
1 Aufgrund ihrer zusätzlichen Vorteile empfehlen wir, wenn möglich, die AWS CRT basierten HTTP Clients zu verwenden.
Standardeinstellungen für die intelligente Konfiguration
Die AWS SDK for Java 2.x (Version 2.17.102 oder höher) bietet eine Funktion für intelligente Standardeinstellungen für Konfigurationen. Diese Funktion optimiert zwei HTTP Client-Eigenschaften zusammen mit anderen Eigenschaften, die den Client nicht beeinflussen. HTTP
Die Standardeinstellungen der intelligenten Konfiguration legen sinnvolle Werte für die tlsNegotiationTimeoutInMillis
Eigenschaften connectTimeoutInMillis
und fest, die auf einem von Ihnen angegebenen Standardmoduswert basieren. Sie wählen den Standardmoduswert auf der Grundlage der Eigenschaften Ihrer Anwendung.
Weitere Informationen zu den Standardeinstellungen für intelligente Konfigurationen und zur Auswahl des Standardmoduswerts, der für Ihre Anwendungen am besten geeignet ist, finden Sie im Referenzhandbuch AWS SDKsund im Tools-Referenzhandbuch.
Im Folgenden finden Sie vier Möglichkeiten, den Standardmodus für Ihre Anwendung festzulegen.
Wenn Sie den Standardmodus global mit der Systemeigenschaft, der Umgebungsvariablen oder der AWS Konfigurationsdatei festlegen, können Sie die Einstellungen beim Erstellen eines HTTP Clients überschreiben.
Wenn Sie mit httpClientBuilder()
dieser Methode einen HTTP Client erstellen, gelten die Einstellungen nur für die Instanz, die Sie gerade erstellen. Ein Beispiel dafür wird hier gezeigt. Der auf Netty basierende HTTP Client in diesem Beispiel überschreibt alle global für und festgelegten Standardmoduswerte. connectTimeoutInMillis
tlsNegotiationTimeoutInMillis