Configure the Apache 5.x based HTTP client
Access the Apache5HttpClient
In order to use the Apache5HttpClient you must add a dependency on apache5-client and
explicitly configure Apache5HttpClient on your service clients.
<dependencyManagement> <dependencies> <dependency> <groupId>software.amazon.awssdk</groupId> <artifactId>bom</artifactId> <version>2.41.0*</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>software.amazon.awssdk</groupId> <artifactId>s3</artifactId> </dependency> <dependency> <groupId>software.amazon.awssdk</groupId> <artifactId>apache5-client</artifactId> </dependency> </dependencies>
*Replace the version shown in red with the version of the Java SDK that you want to use. Find the latest on
Maven Central
Use and configure the Apache5HttpClient
You can configure an instance of Apache5HttpClient along with
building a service client, or you can configure a single instance to share across
multiple service clients.
With either approach, you use the Apache5HttpClient.Builder
Best practice: dedicate an Apache5HttpClient instance to a service client
If you need to configure an instance of the
Apache5HttpClient, we recommend that you build the
dedicated Apache5HttpClient instance. You can do so by
using the httpClientBuilder method of the service client's builder. This way,
the lifecycle of the HTTP client is managed by the SDK, which helps avoid
potential memory leaks if the Apache5HttpClient instance is
not closed down when it's no longer needed.
The following example creates an S3Client and configures the embedded instance
of Apache5HttpClient with maxConnections and connectionTimeout values. The HTTP
instance is created using the httpClientBuilder method of
S3Client.Builder.
Imports
import software.amazon.awssdk.http.apache5.Apache5HttpClient; import software.amazon.awssdk.services.s3.S3Client; import java.time.Duration;
Code
S3Client s3Client = S3Client // Singleton: Use the s3Client for all requests. .builder() .httpClientBuilder(Apache5HttpClient.builder() .maxConnections(100) .connectionTimeout(Duration.ofSeconds(5)) ) .build(); // Perform work with the s3Client. s3Client.close(); // Requests completed: Close all service clients.
Alternative approach: share an Apache5HttpClient instance
To help keep resource and memory usage lower for your application, you can configure an Apache5HttpClient and share it
across multiple service clients. The HTTP connection pool will be shared, which lowers resource usage.
Note
When an Apache5HttpClient instance is shared, you must close it when it is ready to be disposed.
The SDK will not close the instance when the service client is closed.
The following example configures an Apache-based HTTP client that is used by two service clients.
The configured ApacheHttpClient instance is passed to the httpClient method of each builder. When the service clients and the HTTP client are no longer needed, the code explicitly closes them. The code closes the HTTP client last.
Imports
import software.amazon.awssdk.http.SdkHttpClient; import software.amazon.awssdk.http.apache5.Apache5HttpClient; import software.amazon.awssdk.services.dynamodb.DynamoDbClient; import software.amazon.awssdk.services.s3.S3Client;
Code
SdkHttpClient apache5HttpClient = Apache5HttpClient.builder() .maxConnections(100).build(); // Singletons: Use the s3Client and dynamoDbClient for all requests. S3Client s3Client = S3Client.builder() .httpClient(apache5HttpClient).build(); DynamoDbClient dynamoDbClient = DynamoDbClient.builder() .httpClient(apache5HttpClient).build(); // Perform work with the s3Client and dynamoDbClient. // Requests completed: Close all service clients. s3Client.close(); dynamoDbClient.close(); apache5HttpClient.close(); // Explicitly close apache5HttpClient.