JAVA获取ES连接并查询所有数据

我们的项目要获取es连接,新版本和旧版本有不小的区别,在8.17.0版本使用的是

复制代码
ElasticsearchClient
复制代码
<dependency>
    <groupId>co.elastic.clients</groupId>
    <artifactId>elasticsearch-java</artifactId>
    <version>8.17.0</version> <!-- 使用最新版本 -->
</dependency>

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.15.2</version>
</dependency>

初始化代码

复制代码
File certFile = new File(caPath);
        SSLContext sslContext = TransportUtils.sslContextFromHttpCaCrt(certFile);
        BasicCredentialsProvider credsProv = new BasicCredentialsProvider();
        credsProv.setCredentials(
                AuthScope.ANY, new UsernamePasswordCredentials(esUserName, esPwd)
        );
        RestClient restClient = RestClient
                .builder(new HttpHost(esHost, esPort, esHttpType))
                .setHttpClientConfigCallback(hc -> hc
                        .setSSLContext(sslContext)
                        .setDefaultCredentialsProvider(credsProv)
                        .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE)
                )
                .build();
        ElasticsearchTransport transport = new RestClientTransport(restClient, new JacksonJsonpMapper());
        ElasticsearchClient client = new ElasticsearchClient(transport);

循环获取代码

复制代码
SearchResponse<Object> searchResponse = client.search(searchRequest, Object.class);// 执行初始搜索
        List<Hit<Object>> hits = searchResponse.hits().hits();// 获取命中的文档列表

        String scrollId = searchResponse.scrollId();
        // 2. 循环获取所有结果
        boolean isEmpty = false;
        while (scrollId != null && !isEmpty) {
            String finalScrollId1 = scrollId;
            ScrollResponse<Object> scrollResponse = client.scroll(s -> s
                            .scrollId(finalScrollId1)
                            .scroll(Time.of(b -> b.time("30s")))
                    , Object.class);

            scrollId = scrollResponse.scrollId();
            List<Hit<Object>> scrollHits = scrollResponse.hits().hits();
            
        }

        // 最后清除 scroll 上下文
        String finalScrollId = scrollId;
        client.clearScroll(c -> c.scrollId(finalScrollId));
        client.close();
        writer.flush();
        writer.close();

重点关注循环获取数据的内容,通过AI搜索的不一定对,这是经过修改之后的。

相关推荐
万能程序员-传康Kk6 分钟前
智能教育个性化学习平台-java
java·开发语言·学习
落笔画忧愁e16 分钟前
扣子Coze飞书多维表插件-列出全部数据表
java·服务器·飞书
鱼儿也有烦恼18 分钟前
Elasticsearch最新入门教程
java·elasticsearch·kibana
花晓木24 分钟前
Filebeat收集nginx日志到elasticsearch,最终在kibana做展示(二)
elasticsearch·搜索引擎
路修24 分钟前
Spring Boot + Elasticsearch + HBase 构建海量数据搜索系统
spring boot·elasticsearch·hbase
eternal__day28 分钟前
微服务架构下的服务注册与发现:Eureka 深度解析
java·spring cloud·微服务·eureka·架构·maven
一介草民丶35 分钟前
Jenkins | Linux环境部署Jenkins与部署java项目
java·linux·jenkins
武子康43 分钟前
Java-39 深入浅出 Spring - AOP切面增强 核心概念 通知类型 XML+注解方式 附代码
xml·java·大数据·开发语言·后端·spring
米粉03051 小时前
SpringBoot核心注解详解及3.0与2.0版本深度对比
java·spring boot·后端
G皮T1 小时前
【Elasticsearch】Elasticsearch 核心技术(二):映射
大数据·elasticsearch·映射·搜索·动态映射·mappings