JestClient在空闲一段时间后抛出SocketTimeoutException

时间:2018-01-13 04:07:16

标签: java spring elasticsearch javabeans jest

我正在使用JEST连接spring-boot应用程序中的elasticsearch。当应用程序空闲(不向elasticsearch发送任何请求)一段时间后,JestClient就会抛出SocketTImeoutException。我正在使用bean创建客户端:

@Bean
public JestClient client() throws Exception {
    JestClientFactory factory = new JestClientFactory();
    factory.setHttpClientConfig(new HttpClientConfig
        .Builder(esURL)
        .multiThreaded(true)
        .connTimeout(60000)
        .readTimeout(60000)
        .defaultMaxTotalConnectionPerRoute(10)
        .maxTotalConnection(100).build());
    return factory.getObject();
}

这里有什么我想念的吗?

1 个答案:

答案 0 :(得分:2)

我会尝试一个想法:查看此功能 - https://github.com/searchbox-io/Jest/pull/149 - 意思是,配置maxConnectionIdleTime以便在实际使用之前杀死空闲连接(这将导致您获得超时异常) 。测试中的一个例子:https://github.com/searchbox-io/Jest/blob/v2.0.4/jest/src/test/java/io/searchbox/client/JestClientFactoryIntegrationTest.java#L116

关于使用它的值,我不确定网络套接字的超时是什么...猜测30秒。无论你为maxConnectionIdleTime设置什么,它应该小于那个。也许试着从超时中观察你得到的空闲时间保护你,哪些没有。