Clientes de HTTP - AWS SDK for Java 2.x

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

Clientes de HTTP

Puede cambiar el cliente HTTP para usarlo en su cliente de servicio, así como cambiar la configuración predeterminada de los clientes HTTP con AWS SDK for Java 2.x. En esta sección se describen los clientes HTTP y la configuración del SDK.

Clientes HTTP disponibles en el SDK para Java

Clientes síncronos

Los clientes HTTP sincrónicos del SDK para Java implementan la SdkHttpClientinterfaz. Un cliente de servicio síncrono, como el S3Client o el DynamoDbClient, requiere el uso de un cliente HTTP síncrono. AWS SDK for Java Ofrece tres clientes HTTP sincrónicos.

ApacheHttpClient (predeterminado)

ApacheHttpClientes el cliente HTTP predeterminado para los clientes de servicios síncronos. Para obtener información acerca de cómo configurar el ApacheHttpClient, consulte Configurar el cliente HTTP basado en Apache.

AwsCrtHttpClient

AwsCrtHttpClientproporciona E/S de alto rendimiento y sin bloqueo. Se basa en el cliente HTTP AWS Common Runtime (CRT). Para obtener información sobre cómo configurar el AwsCrtHttpClient y utilizar el servicio con los clientes, consulte Configurar clientes AWS HTTP basados en CRT.

UrlConnectionHttpClient

Para minimizar la cantidad de archivos jar y bibliotecas de terceros que utiliza la aplicación, puede utilizar el UrlConnectionHttpClient. Para obtener información acerca de cómo configurar el UrlConnectionHttpClient, consulte Configurar el cliente HTTP basado en URLConnection.

Clientes asíncronos

Los clientes HTTP asíncronos del SDK for Java implementan la interfaz. SdkAsyncHttpClient Un cliente de servicio asíncrono, como el S3AsyncClient o el DynamoDbAsyncClient, requiere el uso de un cliente HTTP asíncrono. AWS SDK for Java Ofrece dos clientes HTTP asíncronos.

NettyNioAsyncHttpClient (predeterminado)

NettyNioAsyncHttpClientes el cliente HTTP predeterminado que utilizan los clientes asíncronos. Para obtener información acerca de cómo configurar el NettyNioAsyncHttpClient, consulte Configurar el cliente HTTP basado en Netty.

AwsCrtAsyncHttpClient

AwsCrtAsyncHttpClientSe basa en el cliente HTTP AWS Common Runtime (CRT). Para obtener información acerca de cómo configurar el AwsCrtAsyncHttpClient, consulte Configurar clientes AWS HTTP basados en CRT.

Recomendaciones sobre el cliente HTTP

Al elegir una implementación de cliente HTTP entran en juego varios factores. Utilice la siguiente información para ayudarle en la decisión.

Diagrama de flujo de recomendaciones

El siguiente diagrama de flujo proporciona una guía general para ayudarle a determinar qué cliente HTTP debe utilizar.

Diagrama de flujo de recomendaciones sobre clientes HTTP.

Comparación de clientes HTTP

La siguiente tabla proporciona información detallada de cada cliente HTTP.

Cliente HTTP Sínc. or asínc. Cuándo se debe usar Limitación o inconveniente
Cliente HTTP basado en Apache

(cliente HTTP de sincronización predeterminado)

Sincronizar Úselo si prefiere una latencia baja en lugar de un alto rendimiento Tiempo de startup más lento en comparación con otros clientes HTTP
Cliente HTTP basado en URLConnection Sincronizar Úselo si tiene requisitos estrictos para limitar las dependencias de terceros No admite el método HTTP PATCH, que requieren algunas API, como las operaciones de actualización de Amazon APIGateway
AWS Cliente HTTP de sincronización basado en CRT 1 Sincronizar

• Úselo si su aplicación se está ejecutando en AWS Lambda

- Utilícelo si prefiere un alto rendimiento a una baja latencia

• Úselo si prefiere clientes del SDK síncronos

N/A
Netty-based HTTP client

(cliente HTTP asíncrono predeterminado)

Asíncrono

• Úselo si su aplicación invoca API que requieren compatibilidad con HTTP/2, como la API de Kinesis SubscribeToShard

Tiempo de startup más lento en comparación con otros clientes HTTP
AWS Cliente HTTP asíncrono basado en CRT 1 Asíncrono

• Úselo si su aplicación se está ejecutando en AWS Lambda

- Utilícelo si prefiere un alto rendimiento a una baja latencia

• Úselo si prefiere clientes del SDK asíncronos

• No es compatible con clientes de servicio que requieran compatibilidad con HTTP/2, como KinesisAsynClient y TranscribeStreamingAsyncClient

1 Debido a sus ventajas adicionales, le recomendamos que utilice los clientes HTTP basados en AWS CRT si es posible.

Valores predeterminados de configuración inteligente

La AWS SDK for Java 2.x versión 2.17.102 o posterior ofrece una función de configuración inteligente por defecto. Esta característica optimiza dos propiedades del cliente HTTP junto con otras propiedades que no afectan al cliente HTTP.

Los valores predeterminados de la configuración inteligente establecen valores razonables para las propiedades connectTimeoutInMillis y tlsNegotiationTimeoutInMillis en función del valor de modo predeterminado que proporcione. El valor de modo predeterminado se elige según las características de la aplicación.

Para obtener más información sobre la configuración inteligente predeterminada y sobre cómo elegir el mejor modo predeterminado para sus aplicaciones, consulte la Guía de referencia de las herramientas y los SDK de AWS.

A continuación, se muestran cuatro formas de configurar el modo predeterminado para su aplicación.

Service client

Utilice el generador de clientes de servicio para configurar el modo predeterminado directamente en el cliente de servicio. El siguiente ejemplo establece el modo predeterminado en auto para el DynamoDbClient.

DynamoDbClient ddbClient = DynamoDbClient.builder() .defaultsMode(DefaultsMode.AUTO) .build();
System property

Puede usar la propiedad del aws.defaultsMode sistema para especificar el modo predeterminado. Si establece la propiedad del sistema en Java, debe establecerla antes de inicializar cualquier cliente de servicio.

En el siguiente ejemplo, se muestra cómo configurar el modo predeterminado en auto usar un conjunto de propiedades del sistema en Java.

System.setProperty("aws.defaultsMode", "auto");

En el siguiente ejemplo, se muestra cómo configurar el modo predeterminado como auto mediante una opción -D del comando java.

java -Daws.defaultsMode=auto
Environment variable

Defina un valor para la variable de entorno AWS_DEFAULTS_MODE para seleccionar el modo predeterminado de la aplicación.

La siguiente información muestra el comando que se debe ejecutar para establecer el valor del modo predeterminado como auto utilizando una variable de entorno.

Sistema operativo Comando para definir variables de entorno

Linux, macOS o Unix

export AWS_DEFAULTS_MODE=auto

Windows

set AWS_DEFAULTS_MODE=auto
AWS config file

Puede añadir una propiedad de defaults_mode configuración al AWS config archivo compartido, como se muestra en el siguiente ejemplo.

[default] defaults_mode = auto

Si define el modo predeterminado de forma global con la propiedad del sistema, la variable de entorno o el archivo de configuración AWS , puede sustituir la configuración cuando cree un cliente HTTP.

Al crear un cliente HTTP con el método httpClientBuilder(), la configuración se aplica solo a la instancia que se está creando. Un ejemplo de ello se muestra aquí. En este ejemplo, el cliente HTTP basado en Netty anula cualquier valor de modo predeterminado establecido globalmente para connectTimeoutInMillis y tlsNegotiationTimeoutInMillis.