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();
        }
    }
相关推荐
jwolf22 小时前
Elasticsearch向量搜索:从语义搜索到图搜图只有一步之遥
elasticsearch·搜索引擎·ai
你可以叫我仔哥呀3 小时前
ElasticSearch学习笔记三:基础操作(一)
笔记·学习·elasticsearch
hummhumm4 小时前
第 25 章 - Golang 项目结构
java·开发语言·前端·后端·python·elasticsearch·golang
java1234_小锋7 小时前
Elasticsearch中的节点(比如共20个),其中的10个选了一个master,另外10个选了另一个master,怎么办?
大数据·elasticsearch·jenkins
Elastic 中国社区官方博客7 小时前
Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
我的运维人生7 小时前
Elasticsearch实战应用:构建高效搜索与分析平台
大数据·elasticsearch·jenkins·运维开发·技术共享
Mephisto.java11 小时前
【大数据学习 | Spark】Spark的改变分区的算子
大数据·elasticsearch·oracle·spark·kafka·memcache
mqiqe11 小时前
Elasticsearch 分词器
python·elasticsearch
小马爱打代码12 小时前
Elasticsearch简介与实操
大数据·elasticsearch·搜索引擎
java1234_小锋20 小时前
Elasticsearch是如何实现Master选举的?
大数据·elasticsearch·搜索引擎