Spring Boot中的Elasticsearch自动配置

news2024/12/29 10:06:33

Spring Boot中的Elasticsearch自动配置

Elasticsearch是一个基于Lucene的分布式全文搜索引擎,它在搜索、分析等方面具有出色的表现。Spring Boot中的Elasticsearch自动配置为我们提供了一种快速集成Elasticsearch的方式,使我们可以在Spring Boot应用程序中轻松地使用Elasticsearch。

本文将介绍Spring Boot中的Elasticsearch自动配置的作用、原理和使用方法。首先,我们将了解Elasticsearch自动配置的作用,然后深入探讨它的原理和如何使用它。

在这里插入图片描述

1. Elasticsearch自动配置的作用

使用Elasticsearch自动配置可以帮助我们轻松地集成Elasticsearch,并提供一些默认的配置,例如连接池、序列化方式、重试机制等,使我们可以更加专注于业务逻辑的实现。

Elasticsearch自动配置为我们提供了一系列简单易用的API,用于实现Elasticsearch的各种操作,例如创建索引、添加文档、搜索、聚合等。使用Elasticsearch自动配置的好处是,它可以帮助我们更快速地集成Elasticsearch。

2. Elasticsearch自动配置的原理

在Spring Boot中,Elasticsearch自动配置是通过ElasticsearchAutoConfiguration类来实现的。该类是Spring Boot Elasticsearch Starter中的一个核心组件,用于自动配置Elasticsearch相关的Bean。

在ElasticsearchAutoConfiguration类中,我们可以看到一系列与Elasticsearch相关的Bean的定义,例如RestHighLevelClient、ElasticsearchTemplate、ElasticsearchRestTemplate等。这些Bean的定义会被自动装配到Spring应用程序中,并通过Spring IoC容器来管理和使用。

以下是ElasticsearchAutoConfiguration类的一个简化版本:

@Configuration(proxyBeanMethods = false)
@ConditionalOnClass(RestHighLevelClient.class)
@AutoConfigureAfter({ ElasticsearchRestClientAutoConfiguration.class })
public class ElasticsearchAutoConfiguration {

    @Bean
    @ConditionalOnMissingBean
    public RestHighLevelClient elasticsearchClient(
            RestClientBuilderCustomizer... restClientBuilderCustomizers) throws Exception {
        return new RestHighLevelClient(
                RestClient.builder(getHostsProperties())
                        .setHttpClientConfigCallback(config -> config
                                .setDefaultCredentialsProvider(getCredentialsProvider()))
                        .setRequestConfigCallback(getRequestConfigCallback())
                        .setHttpClientConfigCallback(httpClientBuilder -> {
                            for (RestClientBuilderCustomizer customizer : restClientBuilderCustomizers) {
                                customizer.customize(httpClientBuilder);
                            }
                        }));
    }

    @Bean
    @ConditionalOnMissingBean
    public ElasticsearchRestTemplate elasticsearchRestTemplate(
            RestHighLevelClient elasticsearchClient) {
        return new ElasticsearchRestTemplate(elasticsearchClient);
    }

}

在这个类中,我们定义了一个名为elasticsearchClient的Bean,它是RestHighLevelClient类型的。这个Bean使用了一个名为getHostsProperties的方法来获取Elasticsearch主机的信息,并使用一个名为getCredentialsProvider的方法来获取凭据。这个Bean还使用一个名为getRequestConfigCallback的方法来获取请求配置回调。

我们还定义了一个名为elasticsearchRestTemplate的Bean,它是ElasticsearchRestTemplate类型的。这个Bean使用了名为elasticsearchClient的Bean作为构造函数参数。

3. Elasticsearch自动配置的使用方法

在Spring Boot中,我们可以通过引入Spring Boot Elasticsearch Starter来使用Elasticsearch自动配置。以下是一个简单的示例:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

在引入Starter之后,我们需要在application.yml或application.properties中配置Elasticsearch相关的属性,例如:

spring:
  elasticsearch:
    rest:
      uris: http://localhost:9200

在配置完成之后,我们就可以通过自动装配的RestHighLevelClient Bean来进行Elasticsearch相关的操作。以下是一个简单的示例:

@Autowired
private ElasticsearchRestTemplate elasticsearchTemplate;

public List<Book> searchBooks(String query) {
    Query searchQuery = new NativeSearchQueryBuilder()
            .withQuery(Query# Spring Boot中的Elasticsearch自动配置

Elasticsearch是一个基于Lucene的分布式全文搜索引擎,它在搜索、分析等方面具有出色的表现。Spring Boot中的Elasticsearch自动配置为我们提供了一种快速集成Elasticsearch的方式,使我们可以在Spring Boot应用程序中轻松地使用Elasticsearch。

本文将介绍Spring Boot中的Elasticsearch自动配置的作用、原理和使用方法。首先,我们将了解Elasticsearch自动配置的作用,然后深入探讨它的原理和如何使用它。

## 1. Elasticsearch自动配置的作用

使用Elasticsearch自动配置可以帮助我们轻松地集成Elasticsearch,并提供一些默认的配置,例如连接池、序列化方式、重试机制等,使我们可以更加专注于业务逻辑的实现。

Elasticsearch自动配置为我们提供了一系列简单易用的API,用于实现Elasticsearch的各种操作,例如创建索引、添加文档、搜索、聚合等。使用Elasticsearch自动配置的好处是,它可以帮助我们更快速地集成Elasticsearch。

## 2. Elasticsearch自动配置的原理

在Spring Boot中,Elasticsearch自动配置是通过ElasticsearchAutoConfiguration类来实现的。该类是Spring Boot Elasticsearch Starter中的一个核心组件,用于自动配置Elasticsearch相关的Bean。

在ElasticsearchAutoConfiguration类中,我们可以看到一系列与Elasticsearch相关的Bean的定义,例如RestHighLevelClientElasticsearchTemplateElasticsearchRestTemplate等。这些Bean的定义会被自动装配到Spring应用程序中,并通过Spring IoC容器来管理和使用。

以下是ElasticsearchAutoConfiguration类的一个简化版本:

```java
@Configuration(proxyBeanMethods = false)
@ConditionalOnClass(RestHighLevelClient.class)
@AutoConfigureAfter({ ElasticsearchRestClientAutoConfiguration.class })
public class ElasticsearchAutoConfiguration {

    @Bean
    @ConditionalOnMissingBean
    public RestHighLevelClient elasticsearchClient(
            RestClientBuilderCustomizer... restClientBuilderCustomizers) throws Exception {
        return new RestHighLevelClient(
                RestClient.builder(getHostsProperties())
                        .setHttpClientConfigCallback(config -> config
                                .setDefaultCredentialsProvider(getCredentialsProvider()))
                        .setRequestConfigCallback(getRequestConfigCallback())
                        .setHttpClientConfigCallback(httpClientBuilder -> {
                            for (RestClientBuilderCustomizer customizer : restClientBuilderCustomizers) {
                                customizer.customize(httpClientBuilder);
                            }
                        }));
    }

    @Bean
    @ConditionalOnMissingBean
    public ElasticsearchRestTemplate elasticsearchRestTemplate(
            RestHighLevelClient elasticsearchClient) {
        return new ElasticsearchRestTemplate(elasticsearchClient);
    }

}

在这个类中,我们定义了一个名为elasticsearchClient的Bean,它是RestHighLevelClient类型的。这个Bean使用了一个名为getHostsProperties的方法来获取Elasticsearch主机的信息,并使用一个名为getCredentialsProvider的方法来获取凭据。这个Bean还使用一个名为getRequestConfigCallback的方法来获取请求配置回调。

我们还定义了一个名为elasticsearchRestTemplate的Bean,它是ElasticsearchRestTemplate类型的。这个Bean使用了名为elasticsearchClient的Bean作为构造函数参数。

3. Elasticsearch自动配置的使用方法

在Spring Boot中,我们可以通过引入Spring Boot Elasticsearch Starter来使用Elasticsearch自动配置。以下是一个简单的示例:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

在引入Starter之后,我们需要在application.yml或application.properties中配置Elasticsearch相关的属性,例如:

spring:
  elasticsearch:
    rest:
      uris: http://localhost:9200

在配置完成之后,我们就可以通过自动装配的RestHighLevelClient Bean来进行Elasticsearch相关的操作。以下是一个简单的示例:

@Autowired
private ElasticsearchRestTemplate elasticsearchTemplate;

public List<Book> searchBooks(String query) {
    Query searchQuery = new NativeSearchQueryBuilder()
            .withQuery(Query.builders.queryStringQuery(query))
            .build();
    return elasticsearchTemplate.queryForList(searchQuery, Book.class);
}

在这个示例中,我们使用了ElasticsearchRestTemplate Bean来执行搜索操作。我们通过构建一个NativeSearchQueryBuilder对象来构建查询,并将其传递给queryForList方法来执行搜索操作。查询结果会被自动映射到Book对象中,并返回一个Book对象列表。

除了搜索操作之外,Spring Boot中的Elasticsearch自动配置还提供了一系列其他的API,例如创建索引、添加文档、删除文档、聚合等。

以下是一个简单的示例,用于向Elasticsearch添加一个文档:

@Autowired
private ElasticsearchRestTemplate elasticsearchTemplate;

public void addBook(Book book) {
    IndexQuery indexQuery = new IndexQueryBuilder()
            .withObject(book)
            .build();
    elasticsearchTemplate.index(indexQuery);
}

在这个示例中,我们使用了IndexQueryBuilder来构建一个IndexQuery对象,并将其传递给index方法来将一个Book对象添加到Elasticsearch中。

4. 总结

Spring Boot中的Elasticsearch自动配置为我们提供了一种快速集成Elasticsearch的方式,使我们可以在Spring Boot应用程序中轻松地使用Elasticsearch。本文介绍了Elasticsearch自动配置的作用、原理和使用方法。我们了解到,Elasticsearch自动配置可以帮助我们轻松地集成Elasticsearch,并提供一些默认的配置,例如连接池、序列化方式、重试机制等,使我们可以更加专注于业务逻辑的实现。使用Elasticsearch自动配置的好处是,它可以帮助我们更快速地集成Elasticsearch,并提供一系列简单易用的API,用于实现Elasticsearch的各种操作。

如果您正在开发一个基于Spring Boot的应用程序,并希望使用Elasticsearch来实现全文搜索功能,那么Spring Boot中的Elasticsearch自动配置是您的一个不错的选择。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/706177.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Unity每日一记】常见的类你都掌握了吗,没有就过来看看吧

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;uni…

layui弹出层laydate时间选择一闪而过,无法弹出时间选择

问题&#xff1a;layUI日期框弹不出&#xff0c;一闪而过 laydate.render({elem: #ctime,type: datetime,trigger:click }); 解决方案&#xff1a;关键代码&#xff0c;添加如下代码 trigger:click 实现效果

浏览器基础原理-安全: HTTPS

HTTP协议的历史: HTTP协议的目的很单纯, 就是为了传输超文本文件, 所以早期的 HTTP 一直保持着明文传输数据的特征, 但是中间很有可能会被截取或者篡改, 即收到中间人攻击. 解析HTTP协议栈层面: HTTPS往里面加入了安全层, 它的指责是: 对发起HTTP请求的数据进行加密和对接收…

Redis实战篇(二)

三、优惠卷秒杀 3.1 全局唯一ID 每个店铺都可以发布优惠券&#xff1a; 当用户抢购时&#xff0c;就会生成订单并保存到tb_voucher_order这张表中&#xff0c;而订单表如果使用数据库自增ID就存在一些问题&#xff1a; id的规律性太明显 受单表数据量的限制 场景分析一&am…

初学mybatis(二)CRUD操作及配置解析

学习回顾&#xff1a;初学mybatis&#xff08;一&#xff09; 一、namespace 1、将上面案例中的UserMapper接口改名为 UserDao&#xff1b;2、将UserMapper.xml中的namespace改为为UserDao的路径 .3、再次测试 结论&#xff1a; 配置文件中namespace中的名称为对应Mapper接口或…

Python基本操作

前言 啦啦啦&#xff0c;现在开始,打算做一期Python基础教程&#xff0c;欢迎大家来看哦&#xff01; 导读 这期文章真的是Python基础中的基础&#xff0c;相信有一定编程基础的小伙伴们都一定能看懂的… 本文共分为以下几个部分&#xff1a; 数与运算符基本输入输出注释模…

Linux环境安装openJDK

现在越来越多的开发者使用 openJDK &#xff0c;当然这也是一种趋势 官网下载&#xff1a; https://jdk.java.net/java-se-ri/8-MR5这里以 jdk8 为例 配置环境变量 看网上的教程&#xff0c;好多人都推荐去这个官网下载&#xff1a; https://hg.openjdk.org/其实这个是 O…

算法笔记——数组篇

整理一下刷过的题型&#xff0c;持续更新&#xff0c;参照代码随想录 代码随想录数组篇 二分法 力扣相关题目&#xff1a; 704. 二分查找 只适用于排序有序数组&#xff0c;且没有重复元素。主要是有两种写法&#xff0c;二分查找涉及的很多的边界条件&#xff0c;逻辑比较简单…

V-Box智能车载终端-OBUYZN2

1 产品概览 OBUYZN2型智能车载终端&#xff08;以下简称&#xff09;是 型智能车载终端&#xff08;以下简称&#xff09;是 型智能车载终端&#xff08;以下简称&#xff09;是 型智能车载终端&#xff08;以下简称&#xff09;是 组成智能网联 系统 的核心数据交互设备 &…

Java 顶层类(top-level class)的访问控制修饰符

在Java中&#xff0c;处于最外层的类就是顶层类&#xff08;top-level class&#xff09;&#xff0c;类的声明外面再没有其它的类包裹。 顶层类的访问控制修饰符只能是public、或者包访问控制修饰符&#xff08;也就是无访问控制修饰符&#xff09;。 访问控制修饰符访问范围…

用codetyphon开发一个单机版跨平台数据处理小软件

目录 1 前言 2 一种可能的方案 2.1 数据存储使用dbf格式 2.2 用Lazarus或CT开发 2.3 根据外部csv或者excel电子表格快速建表 2.4 用python汇总和审核 3 当前进度 3.1 根据excel电子表格快速自动建表和导入数据 3.2 显示数据 3.3 建立测试数据库 1 前言 现在各种现成的…

Vue天气案例

绑定事件的时候&#xff1a;xxx"yyy" yyy可以写一些简单的语句。 <body><div id"root"><h2>今天天气很{{info}}</h2><button click"changeWether">切换天气</button></div> </body><scr…

HBase-问题

最终理解HBase数据模型的关键在于稀疏、分布式、多维、排序的映射。其中映射map指代非关系型数据库的key-Value结构。 1.怎么理解稀疏&#xff1f; 不同的行有不同的列&#xff0c;这就叫稀疏 有的行有3个列&#xff0c;有的行有2个列&#xff0c;那么2个列的在显示的时候&a…

Unity之穿山甲SDK

SDK版本相关问题官网解答记录: 官网咨询工单地址记录&#xff1a; https://www.csjplatform.com/athena/user-feedback/order/list?identify_keycb790ca553ed7253d29a4dbd4041281b62c449f55d6faaeb4e744370c9b34e38&init_id652798&order_id652798

解决AntvX6的阴影残留

问题描述&#xff1a;在使用antVX6的过程中&#xff0c;有时候重选渲染会出现阴影残留。 解决&#xff1a; 每次重新渲染画布时&#xff0c;使用 clearCells API清除一下画布即可解决。 ... const graph new Graph({container: document.getElementById("app"),w…

高性能分布式缓存Redis(二) 高级应用

一、持久化原理 持久化 Redis是内存数据库&#xff0c;数据都是存储在内存中&#xff0c;为了避免进程退出导致数据的永久丢失&#xff0c;需要定期将Redis中的数据以某种形式(数据或命令)从内存保存到硬盘&#xff1b;当下次Redis重启时&#xff0c;利用持久化文件实现数据恢…

UE4/5数字人Metahuman与Style3D的使用【一、Style3DAtelier软件制作smd格式衣服并导入ue】

目录 软件和插件下载 安装软件Style3DAtelier 放入插件 布料模拟制作&#xff1a; 导出人物 &#xff1a; 数字人与小白人 Style3D添加衣服&#xff1a; 导入小白人或数字人&#xff1a; 身高修改&#xff1a; uv调整 模拟查看情况&#xff1a; 导出smd格式&#x…

0. 开篇词 —— 风物长宜放眼量

个人简介 我是一名工作了6年的 Java 工程师&#xff0c;日常主要工作就是业务功能开发&#xff0c;但是业余时间喜欢研究一些开源框架和流行的技术。我本人是经典 ORM 框架 MyBatis 的 Contributor&#xff0c;同时也是微服务框架 Nacos 的核心 Contributor 和 gorm 的Contrib…

GPT3学习笔记

GPT-3概述 关于GPT-3的主要事实: 模型分类:GPT-3有8个不同的模型&#xff0c;参数从1.25亿到1750亿不等。 模型大小:最大的GPT-3模型有1750亿参数。这比最大的BERT模型大470倍(3.75亿个参数) 体系结构:GPT-3是一种自回归模型&#xff0c;使用仅有解码器的体系结构。使用下一…

mac ppt设置起始页码

今天发现我的ppt的左边ppt的缩略图的开始页码是从2开始的&#xff0c;觉得很奇怪&#xff0c;这个解决的办法就是 点击ppt->文件->页面设置->页眉和页脚->幻灯片编号