当前位置: 首页 > news >正文

Java实战:Spring Boot集成Elasticsearch全文搜索引擎

本文将详细介绍如何在Spring Boot应用程序中集成Elasticsearch全文搜索引擎。我们将探讨Elasticsearch的基本概念,以及如何使用Spring Boot和Spring Data Elasticsearch模块来实现全文搜索功能。此外,我们将通过具体的示例来展示如何在Spring Boot应用程序中配置和使用Elasticsearch,以及如何实现文档索引、搜索和删除等功能。本文适合希望使用Elasticsearch进行全文搜索的Spring Boot开发者阅读。

一、引言

在现代Web应用程序中,全文搜索引擎是一个关键组件,用于提供高效的搜索和数据检索功能。Elasticsearch是一个流行的开源全文搜索引擎,它基于Ruby on Rails开发,并支持分布式搜索和实时搜索等功能。Spring Boot提供了一种简便的方式来集成Elasticsearch全文搜索引擎,以实现快速和灵活的全文搜索。本文将介绍如何在Spring Boot应用程序中集成Elasticsearch全文搜索引擎。

二、Elasticsearch的基本概念

1. 什么是Elasticsearch?
Elasticsearch是一个开源的分布式全文搜索引擎,基于Ruby on Rails开发。它支持分布式搜索和实时搜索等功能,并提供了丰富的查询DSL(Domain Specific Language,领域特定语言)和RESTful API。Elasticsearch通常用于构建大规模的搜索应用程序,如电商网站、内容管理系统等。
2. Elasticsearch的主要组件

  • 节点(Node):Elasticsearch中的节点是构成Elasticsearch集群的基本单位,每个节点都包含一个或多个索引。
  • 索引(Index):索引是Elasticsearch中的核心概念,用于存储相关的文档和元数据。
  • 文档(Document):文档是Elasticsearch中的最小数据单元,它包含了一系列的字段和相关的数据。
  • 映射(Mapping):映射是定义文档结构和字段类型的过程,它告诉Elasticsearch如何存储和索引文档。

三、在Spring Boot中集成Elasticsearch

1. 添加Spring Data Elasticsearch依赖
在项目的pom.xml文件中,添加Spring Boot的Spring Data Elasticsearch依赖:

<dependencies><!-- Spring Boot Web依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- Spring Boot Data Elasticsearch依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId></dependency>
</dependencies>

2. 配置Elasticsearch
在application.properties或application.yml文件中,配置Elasticsearch的基本信息,如服务器地址、端口等。例如:

# application.properties
spring.data.elasticsearch.cluster-nodes=127.0.0.1:9300
spring.data.elasticsearch.cluster-name=elasticsearch

3. 创建Elasticsearch配置类
创建一个Elasticsearch配置类,用于配置Elasticsearch连接工厂和索引操作。以下是一个简单的Elasticsearch配置类示例:

package com.example.demo.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.elasticsearch.config.AbstractElasticsearchConfiguration;
import org.springframework.data.elasticsearch.core.ElasticsearchRestTemplate;
@Configuration
public class ElasticsearchConfig extends AbstractElasticsearchConfiguration {@Overridepublic ElasticsearchRestTemplate elasticsearchTemplate() {return new ElasticsearchRestTemplate(elasticsearchClient());}
}

在上面的代码中,我们创建了一个名为ElasticsearchConfig的配置类,它继承自AbstractElasticsearchConfiguration类。这个类用于配置Elasticsearch连接工厂,并创建一个ElasticsearchRestTemplate对象,用于执行索引操作。

四、实现文档索引、搜索和删除等功能

1. 创建文档实体类
创建一个简单的文档实体类,用于表示要索引的文档。以下是一个简单的文档实体类示例:

package com.example.demo.entity;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;
@Document(indexName = "my_index")
public class MyDocument {@Idprivate String id;@Field(type = FieldType.Text)private String title;@Field(type = FieldType.Text)private String content;// getter和setter方法
}

在上面的代码中,我们创建了一个名为MyDocument的文档实体类。我们使用@Document注解来指定索引的名称,使用@Id注解来指定文档的ID,使用@Field注解来指定文档的字段和类型。
2. 创建文档存储仓库
创建一个文档存储仓库接口,用于实现文档的索引、搜索和删除等功能。以下是一个简单的文档存储仓库接口示例:

package com.example.demo.repository;
import com.example.demo.entity.MyDocument;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;
public interface MyDocumentRepository extends ElasticsearchRepository<MyDocument, String> {
}

在上面的代码中,我们创建了一个名为MyDocumentRepository的文档存储仓库接口,它继承自ElasticsearchRepository接口。这个接口提供了许多用于文档操作的方法,如savefindByIdfindAlldelete等。
3. 实现文档索引
创建一个服务类,用于实现文档的索引功能。以下是一个简单的服务类示例:

package com.example.demo.service;
import com.example.demo.entity.MyDocument;
import com.example.demo.repository.MyDocumentRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class MyDocumentService {@Autowiredprivate MyDocumentRepository myDocumentRepository;public void indexDocument(MyDocument document) {myDocumentRepository.save(document);}
}

在上面的代码中,我们创建了一个名为MyDocumentService的服务类,它包含一个名为indexDocument的方法,用于实现文档的索引功能。我们使用MyDocumentRepository接口的save方法来保存文档。
4. 实现文档搜索
创建一个服务类,用于实现文档的搜索功能。以下是一个简单的服务类示例:

package com.example.demo.service;
import com.example.demo.entity.MyDocument;
import com.example.demo.repository.MyDocumentRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class MyDocumentSearchService {@Autowiredprivate MyDocumentRepository myDocumentRepository;public List<MyDocument> searchDocuments(String query) {return myDocumentRepository.search(query).getContent();}
}

在上面的代码中,我们创建了一个名为MyDocumentSearchService的服务类,它包含一个名为searchDocuments的方法,用于实现文档的搜索功能。我们使用MyDocumentRepository接口的search方法来执行搜索查询,并获取搜索结果。
5. 实现文档删除
创建一个服务类,用于实现文档的删除功能。以下是一个简单的服务类示例:

package com.example.demo.service;
import com.example.demo.entity.MyDocument;
import com.example.demo.repository.MyDocumentRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class MyDocumentDeleteService {@Autowiredprivate MyDocumentRepository myDocumentRepository;public void deleteDocument(String id) {myDocumentRepository.deleteById(id);}
}

在上面的代码中,我们创建了一个名为MyDocumentDeleteService的服务类,它包含一个名为deleteDocument的方法,用于实现文档的删除功能。我们使用MyDocumentRepository接口的deleteById方法来删除具有指定ID的文档。

五、总结

本文详细介绍了如何在Spring Boot应用程序中集成Elasticsearch全文搜索引擎。我们首先了解了Elasticsearch的基本概念和主要组件。然后,我们学习了如何使用Spring Boot和Spring Data Elasticsearch模块来实现全文搜索功能,包括添加依赖、配置Elasticsearch、创建Elasticsearch配置类、创建文档实体类、创建文档存储仓库、实现文档索引、搜索和删除等功能。
通过本文,您应该已经掌握了如何使用Spring Boot集成Elasticsearch全文搜索引擎,以及如何实现高效和灵活的全文搜索。您学会了如何添加Spring Data Elasticsearch依赖、配置Elasticsearch、创建文档实体类和仓库、实现文档索引、搜索和删除等功能。希望本文能够帮助您在开发Spring Boot应用程序时更加得心应手。如果您有任何疑问或建议,请随时留言交流。

相关文章:

Java实战:Spring Boot集成Elasticsearch全文搜索引擎

本文将详细介绍如何在Spring Boot应用程序中集成Elasticsearch全文搜索引擎。我们将探讨Elasticsearch的基本概念&#xff0c;以及如何使用Spring Boot和Spring Data Elasticsearch模块来实现全文搜索功能。此外&#xff0c;我们将通过具体的示例来展示如何在Spring Boot应用程…...

python 进程笔记二(通讯) (概念+示例代码)

1、为什么要掌握进程间通信 Python代码效率由于受制于GIL全局锁限制&#xff0c;多线程不能利用多核CPU来加速&#xff0c;而多进程方式却可以绕过GIL限制, 发挥多CPU加速的优势&#xff0c;达到提高程序的性能的目的。 然而进程间通信却是不得不考虑的问题。 进程不同于线程&a…...

电机控制-----电机极对数,相电感,相电阻以及磁链常数的测量

电机控制-----电机极对数&#xff0c;相电感&#xff0c;相电阻以及磁链常数的测量 我们在做电机控制的时候&#xff0c;拿到一个电机首先要知道它的参数&#xff0c;然后才能进行相应的开发&#xff0c;我这里介绍的是通过平常常用的手段去获得电机的参数&#xff1a;极对数&…...

SQL注入之oracle注入+SQLbypass+sqlmap实战

学习路还很长&#xff0c;切莫轻言放弃&#xff01; 目录 Oracle数据库介绍 Oracle数据库和MySQL数据库的差别 Oracle数据库注入 SQLbypass姿势 sqlmap工具实战(kali自带) Oracle数据库介绍 Oracle数据库是全球最知名的关系型数据库管理系统&#xff08;RDBMS&#xff09…...

【GPTs分享】GPTs分享之Write For Me

Write For Me 是一个专门定制的GPT版本&#xff0c;旨在为用户提供高质量的文本内容创作服务。它适用于各种写作需求&#xff0c;从商业计划、学术文章到创意故事等。下面是从简介、主要功能、使用案例、优点和局限性几个方面对Write For Me 的详细介绍。 简介 Write For Me …...

css4浮动+清除浮动

浮动 一.常见网页布局1.三种布局方式2.布局准则 二.浮动&#xff08;float&#xff09;1.好处2.概念3.三大特性4.使用5.常见网页布局模板6.注意点 三.清除浮动1.why2.本质3.语法4.四种way&#xff08;后三个都是给父级添加&#xff09;清除浮动总结 一.常见网页布局 1.三种布局…...

外包干了3个月,技术倒退明显...

先说情况&#xff0c;大专毕业&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近6年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试&#xf…...

STM32控制数码管从0显示到99

首先 先画电路图吧&#xff01;打开proteus&#xff0c;导入相关器件&#xff0c;绘制电路图。如下&#xff1a;&#xff08;记得要保存啊&#xff01;发现模拟一遍程序就自动退出了&#xff0c;有bug&#xff0c;我是解决不了&#xff0c;所以就是要及时保存&#xff0c;自己重…...

【机器学习算法】KNN鸢尾花种类预测案例和特征预处理。全md文档笔记(已分享,附代码)

本系列文章md笔记&#xff08;已分享&#xff09;主要讨论机器学习算法相关知识。机器学习算法文章笔记以算法、案例为驱动的学习&#xff0c;伴随浅显易懂的数学知识&#xff0c;让大家掌握机器学习常见算法原理&#xff0c;应用Scikit-learn实现机器学习算法的应用&#xff0…...

Windows 自带的 Linux 子系统(WSL)安装与使用

WSL官网安装教程&#xff1a; https://learn.microsoft.com/zh-cn/windows/wsl/install Windows 自带的Linux子系统&#xff0c;比用VM什么的香太多了。可以自己看官方教程&#xff0c;也可以以下步骤完成。 如果中间遇到我没遇到的问题百度&#xff0c;可以在评论区评论&#…...

C语言--贪吃蛇

目录 1. 实现目标2. 需掌握的技术3. Win32 API介绍控制台程序控制台屏幕上的坐标COORDGetStdHandleGetConsoleCursorinfoCONSOLE_CURSOR_INFOSetConsoleCursorInfoSetConsoleCursorPositionGetAsyncKeyState 4. 贪吃蛇游戏设计与分析地图<locale.h>本地化类项setlocale函…...

原型设计工具Axure RP

Axure RP是一款专业的快速原型设计工具。Axure&#xff08;发音&#xff1a;Ack-sure&#xff09;&#xff0c;代表美国Axure公司&#xff1b;RP则是Rapid Prototyping&#xff08;快速原型&#xff09;的缩写。 下载链接&#xff1a;https://www.axure.com/ 下载 可以免费试用…...

HeadFirst读书笔记

一、设计模式入门 1、使用模式最好的方式“把模式装进脑子里&#xff0c;然后在你的设计和已有的应用中&#xff0c;寻找何处可以使用它们”。以往是代码复用&#xff0c;现在是经验复用。 2、软件开发的一个不变的真理就是变化。 二、设计原则 1、找出应用中可能需要变化之…...

【C++】---内存管理new和delete详解

一、C/C内存分布 C/C内存被分为6个区域&#xff1a; &#xff08;1&#xff09; 内核空间&#xff1a;存放内核代码和环境变量。 &#xff08;2&#xff09;栈区&#xff1a;向下增长&#xff08;存放非静态局部变量&#xff0c;函数参数&#xff0c;返回值等等&#xff09; …...

go-zero微服务入门教程

go-zero微服务入门教程 本教程主要模拟实现用户注册和用户信息查询两个接口。 准备工作 安装基础环境 安装etcd&#xff0c; mysql&#xff0c;redis&#xff0c;建议采用docker安装。 MySQL安装好之后&#xff0c;新建数据库dsms_admin&#xff0c;并新建表sys_user&#…...

蓝桥杯刷题--python-12

3768. 字符串删减 - AcWing题库 nint(input()) sinput() res0 i0 while(i<n): if s[i]x: ji1 while(j<n and s[j]x): j1 resmax(j-i-2,0) ij else: i1 print(res) 3777. 砖块 - AcWing题库 # https://www.a…...

LeetCode LCR 085.括号生成

正整数 n 代表生成括号的对数&#xff0c;请设计一个函数&#xff0c;用于能够生成所有可能的并且 有效的 括号组合。 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;[“((()))”,“(()())”,“(())()”,“()(())”,“()()()”] 示例 2&#xff1a; 输入&#x…...

抖音视频评论数据提取软件|抖音数据抓取工具

一、开发背景&#xff1a; 在业务需求中&#xff0c;我们经常需要下载抖音视频。然而&#xff0c;在网上找到的视频通常只能通过逐个复制链接的方式进行抓取和下载&#xff0c;这种操作非常耗时。我们希望能够通过关键词自动批量抓取并选择性地下载抖音视频。因此&#xff0c;为…...

【web】云导航项目部署及环境搭建(复杂)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、项目介绍1.1项目环境架构LNMP1.2项目代码说明 二、项目环境搭建2.1 Nginx安装2.2 php安装2.3 nginx配置和php配置2.3.1 修改nginx文件2.3.2 修改vim /etc/p…...

软件测试人员必会的linux命令

文件和目录操作: ● ls:列出目录中的文件和子目录。 ● cd:改变当前工作目录。 ● mkdir:创建新目录。 ● rm:删除文件或目录。 ● cp:复制文件或目录。 ● mv:移动或重命名文件或目录。 文本查看和编辑: ● cat:查看文件内容。 ● more或less:分页查看文件内…...

日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする

日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする 1、前言(1)情况说明(2)工程师的信仰2、知识点(1) にする1,接续:名词+にする2,接续:疑问词+にする3,(A)は(B)にする。(2)復習:(1)复习句子(2)ために & ように(3)そう(4)にする3、…...

Nuxt.js 中的路由配置详解

Nuxt.js 通过其内置的路由系统简化了应用的路由配置&#xff0c;使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

【论文阅读28】-CNN-BiLSTM-Attention-(2024)

本文把滑坡位移序列拆开、筛优质因子&#xff0c;再用 CNN-BiLSTM-Attention 来动态预测每个子序列&#xff0c;最后重构出总位移&#xff0c;预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵&#xff08;S…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

【电力电子】基于STM32F103C8T6单片机双极性SPWM逆变(硬件篇)

本项目是基于 STM32F103C8T6 微控制器的 SPWM(正弦脉宽调制)电源模块,能够生成可调频率和幅值的正弦波交流电源输出。该项目适用于逆变器、UPS电源、变频器等应用场景。 供电电源 输入电压采集 上图为本设计的电源电路,图中 D1 为二极管, 其目的是防止正负极电源反接, …...

Caliper 配置文件解析:fisco-bcos.json

config.yaml 文件 config.yaml 是 Caliper 的主配置文件,通常包含以下内容: test:name: fisco-bcos-test # 测试名称description: Performance test of FISCO-BCOS # 测试描述workers:type: local # 工作进程类型number: 5 # 工作进程数量monitor:type: - docker- pro…...

【Veristand】Veristand环境安装教程-Linux RT / Windows

首先声明&#xff0c;此教程是针对Simulink编译模型并导入Veristand中编写的&#xff0c;同时需要注意的是老用户编译可能用的是Veristand Model Framework&#xff0c;那个是历史版本&#xff0c;且NI不会再维护&#xff0c;新版本编译支持为VeriStand Model Generation Suppo…...

基于单片机的宠物屋智能系统设计与实现(论文+源码)

本设计基于单片机的宠物屋智能系统核心是实现对宠物生活环境及状态的智能管理。系统以单片机为中枢&#xff0c;连接红外测温传感器&#xff0c;可实时精准捕捉宠物体温变化&#xff0c;以便及时发现健康异常&#xff1b;水位检测传感器时刻监测饮用水余量&#xff0c;防止宠物…...

[特殊字符] 手撸 Redis 互斥锁那些坑

&#x1f4d6; 手撸 Redis 互斥锁那些坑 最近搞业务遇到高并发下同一个 key 的互斥操作&#xff0c;想实现分布式环境下的互斥锁。于是私下顺手手撸了个基于 Redis 的简单互斥锁&#xff0c;也顺便跟 Redisson 的 RLock 机制对比了下&#xff0c;记录一波&#xff0c;别踩我踩过…...

DAY 45 超大力王爱学Python

来自超大力王的友情提示&#xff1a;在用tensordoard的时候一定一定要用绝对位置&#xff0c;例如&#xff1a;tensorboard --logdir"D:\代码\archive (1)\runs\cifar10_mlp_experiment_2" 不然读取不了数据 知识点回顾&#xff1a; tensorboard的发展历史和原理tens…...