Configuring timeouts in the Elasticsearch Java REST 5 client
You can set timeouts when building the Rest5Client:
- The connect timeout is the maximum time for establishing a TCP connection, including the TLS handshake. The connect timeout is set on
ConnectionConfig. - The socket timeout is the maximum time to wait for I/O on an established socket. The socket timeout is set on
ConnectionConfig. - The response timeout is the maximum period to wait for response data. The response timeout is set on
RequestConfig. - The connection request timeout is the maximum time for leasing a connection from the pool. The connection request timeout is set on
RequestConfig.
To configure timeouts, use setConnectionConfigCallback and setRequestConfigCallback while building the Rest5Client. The following example sets a 10-second connect timeout, a 10-second socket timeout, and a 20-second response timeout:
Rest5ClientBuilder builder = Rest5Client .builder(new HttpHost("http", "localhost", 9200)) .setConnectionConfigCallback(connectConf -> connectConf .setConnectTimeout(Timeout.ofSeconds(10)) .setSocketTimeout(Timeout.ofSeconds(10))) .setRequestConfigCallback(r -> r .setResponseTimeout(Timeout.ofSeconds(20)) ); - Specify
httpsfor TLS.
You can also set per-request timeouts using RequestOptions, which override the builder defaults. The following example sets a response timeout of 60 seconds, as well as a connection request timeout of 1 second (to limit pooled connection wait time):
RequestConfig requestConfig = RequestConfig.custom() .setResponseTimeout(Timeout.ofSeconds(60)) .setConnectionRequestTimeout(Timeout.ofSeconds(1)) .build(); RequestOptions options = RequestOptions.DEFAULT.toBuilder() .setRequestConfig(requestConfig) .build(); ElasticsearchTransport transport = new Rest5ClientTransport( restClient, new JacksonJsonpMapper(), options);