SpringBoot3整合elasticsearch8

版本

SpringBoot == 3.0

Elasticsearch == 8.12.1

依赖

我使用的

复制代码
<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

还可以用,但我没用的。1,2一起用会报下面第一个错

bash 复制代码
<dependency>
    <groupId>co.elastic.clients</groupId>
    <artifactId>elasticsearch-java</artifactId>
    <version>8.12.1</version>
</dependency>

注意:elasticsearch7.17版本之前使用的是,现在已经被弃用

bash 复制代码
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>7.17.18</version>
</dependency>

资料

之前看的elasticsearch7.17之前如何做的:链接

elasticsearch7.17以上的代码示例:链接

官方文档:链接

一个介绍:链接

报错

错误1:Correct the classpath of your application so that it contains compatible versions of the classes org

我的解决方法就是只用第一个依赖

错误2:Error deserializing co.elastic.clients.elasticsearch.core.search.Hit: jakarta.json.JsonException: Ja

解决方法

其他

贴一个,elasticsearch7.17之前的配置,但最好还是用最新的方法

java 复制代码
@Data
@Configuration
@ConfigurationProperties(prefix = "es")
public class ESConfig {
    private String esUrl;
    private String esUsername;
    private String esPassword;

    @Bean
    public RestHighLevelClient configRestHighLevelClient() throws Exception {
        String[] esUrlArr = esUrl.split(",");
        List<HttpHost> httpHosts = new ArrayList<>();
        for(String es : esUrlArr){
            String[] esUrlPort = es.split(":");
            httpHosts.add(new HttpHost(esUrlPort[0], Integer.parseInt(esUrlPort[1]), "http"));
        }

        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY,
                new UsernamePasswordCredentials(esUsername, esPassword));

        RestClientBuilder builder = RestClient.builder(httpHosts.toArray(new HttpHost[0]))
                .setHttpClientConfigCallback(httpClientBuilder -> httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider));
        System.out.println("ES配置完成");
        return new RestHighLevelClient(builder);
    }
}
java 复制代码
@org.junit.Test
    public void getDocument() throws Exception {
        try (RestHighLevelClient client = new ESConfig().configRestHighLevelClient()) {
            // 指定要搜索的索引名称
            String indexName = "cartoon_reply_info";

            // 创建搜索请求对象
            SearchRequest searchRequest = new SearchRequest(indexName);

            // 创建搜索请求的查询条件
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            searchSourceBuilder.query(QueryBuilders.matchQuery("content", "世界"));
            searchSourceBuilder.query(QueryBuilders.matchAllQuery()); // 匹配所有文档
            searchSourceBuilder.size(10); // 设置返回结果的数量
            searchSourceBuilder.sort("mediaId", SortOrder.DESC); // 根据字段排序
            searchSourceBuilder.highlighter(new HighlightBuilder().field("世界")); // 设置高亮字段
            searchSourceBuilder.size(10);
            // 将查询条件添加到搜索请求中
            searchRequest.source(searchSourceBuilder);

            // 执行搜索请求
            SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);

            // 处理搜索结果
            // 您可以从 searchResponse 中获取搜索结果并进行进一步的处理
            // 示例中省略了处理过程
            for (SearchHit hit : searchResponse.getHits().getHits()) {
                System.out.println(hit.getSourceAsString()); // 输出文档内容
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
相关推荐
2301_781668617 小时前
Elasticsearch 02
大数据·elasticsearch·搜索引擎
赵孝正13 小时前
GitLab 分支管理与 Push 问题全解析
大数据·elasticsearch·gitlab
一刀到底21114 小时前
springboot3.3.5 集成elasticsearch8.12.2 ssl 通过 SSL bundle name 来实现
网络·elasticsearch·ssl·springboot3
Elasticsearch15 小时前
Elasticsearch:智能搜索的 MCP
elasticsearch
AAA修煤气灶刘哥2 天前
ES 地理查询玩明白,产品要的 “附近的店” 再也难不倒我!(附 DSL+Java 实战)
java·后端·elasticsearch
AAA修煤气灶刘哥2 天前
ES 聚合爽到飞起!从分桶到 Java 实操,再也不用翻烂文档
后端·elasticsearch·面试
Elasticsearch2 天前
Elastic Observability 中 Discover 的跟踪,用于深入的应用洞察
elasticsearch
Elasticsearch2 天前
使用 cloud-native Elasticsearch 与 ECK 运行
elasticsearch
在未来等你2 天前
Elasticsearch面试精讲 Day 9:复合查询与过滤器优化
大数据·分布式·elasticsearch·搜索引擎·面试
boonya2 天前
Elasticsearch核心原理与面试总结
大数据·elasticsearch·面试