Elasticsearch Connection is closed全文检索连接问题

Elasticsearch全文检索连接问题

Caused by: java.lang.RuntimeException: Connection is closed at 
org.springframework.data.elasticsearch.core.ElasticsearchRestTemplate.translateException
(ElasticsearchRestTemplate.java:425) ~[spring-data-elasticsearch-4.3.2.jar:4.3.2] ... 
54 common frames omitted

大概就是说:连接已在org.springframework.data.elasticsearch.core处被关闭。

个人觉得是长时间没使用导致连接断开。

解决方法

在elasticsearch配置类加上长连接

.setHttpClientConfigCallback(httpClientBuilder ->{
                        	 httpClientBuilder.setKeepAliveStrategy(((httpResponse, httpContext) -> Duration.ofMinutes(3).toMillis()));
                        	 httpClientBuilder.disableAuthCaching();
                    return httpClientBuilder;

这是我完整的配置类:

@Component
@ConfigurationProperties("es")
@Data
public class ESConfig {

    @Value("${es.ip}")
    private String ip;
    @Value("${es.port}")
    private int port;

    @Bean
    public RestHighLevelClient restHighLevelClient(){
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost(ip,port,"http")
                )
                       //配置长连接setHttpClientConfigCallback   默认 net.ipv4.tcp_keepalive_time = 7200s
                        .setHttpClientConfigCallback(httpClientBuilder ->{
                        	 httpClientBuilder.setKeepAliveStrategy(((httpResponse, httpContext) -> Duration.ofMinutes(3).toMillis()));
                        	 httpClientBuilder.disableAuthCaching();
//                    httpClientBuilder.setDefaultIOReactorConfig(IOReactorConfig.custom()
//                            .setSoKeepAlive(true)
//                            .build());
                    return httpClientBuilder;
                })
        );
        return client;
    }


}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Elasticsearch(简称ES)是一个开源的分布式搜索和分析引擎,它基于Apache Lucene库构建而成。它被设计用于快速、可扩展和分布式的全文检索,以及实时数据分析。ES具有强大的搜索能力和高效的分布式架构,能够处理大规模数据的存储、搜索和分析。 ES的核心概念是索引(Index)、文档(Document)和类型(Type)。索引是包含一系列文档的逻辑容器,每个文档都是一个JSON格式的数据对象,可以被索引和搜索。类型是文档的逻辑分类,用于区分不同类型的文档。ES提供了丰富的搜索功能,包括全文搜索、过滤器、聚合等,通过使用查询语言来实现灵活的搜索需求。 ES的分布式特性使得它非常适合处理大规模数据。它使用分片(Shard)和复制(Replica)机制来实现数据的分布和冗余备份,提高了系统的可用性和扩展性。每个索引可以被划分为多个分片,每个分片可以被部署在不同的节点上,从而实现数据的并行处理和负载均衡。 除了全文检索外,ES还提供了丰富的数据分析功能。它支持实时的数据聚合和可视化,可以用于实时监控、日志分析、业务指标分析等场景。ES还可以与其他工具和框架集成,如Kibana(可视化工具)、Logstash(日志收集工具)等,形成完整的日志分析和监控系统。 总而言之,Elasticsearch是一个强大的全文检索和分析引擎,具有高效的搜索能力、可扩展的分布式架构和丰富的数据分析功能。它在各种场景下都能发挥重要作用,包括企业搜索、电商商品搜索、日志分析等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值