教程:Spring Boot中集成Elasticsearch的步骤

简介: 教程:Spring Boot中集成Elasticsearch的步骤

教程:Spring Boot中集成Elasticsearch的步骤


在当今大数据时代,搜索功能对于许多应用程序至关重要。Elasticsearch作为一款开源的分布式搜索引擎,提供了强大的全文搜索和分析能力,广泛应用于日志分析、实时数据分析和搜索引擎等场景。本文将详细介绍如何在Spring Boot应用中集成Elasticsearch,为开发者展示一条通向高效搜索解决方案的道路。


准备工作

在开始之前,请确保你已经完成以下准备工作:

  • JDK 8及以上版本
  • Maven作为项目构建工具
  • Spring Boot框架
  • Elasticsearch服务器

确保你的开发环境已经配置好,并且可以访问到Elasticsearch服务器。

集成Spring Boot与Elasticsearch

添加依赖

首先,在你的Spring Boot项目的pom.xml文件中添加以下依赖:

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

这个依赖将会自动配置Elasticsearch的相关组件,使得我们可以方便地在Spring Boot应用中使用Elasticsearch。

配置Elasticsearch连接

application.propertiesapplication.yml中添加Elasticsearch的连接配置:

spring.data.elasticsearch.cluster-nodes=localhost:9200
spring.data.elasticsearch.cluster-name=my-elasticsearch-cluster

这里,cluster-nodes指定了Elasticsearch服务器的地址和端口,cluster-name是Elasticsearch集群的名称。

定义实体类

接下来,定义一个实体类,并使用Spring Data的注解来映射到Elasticsearch中的索引和文档类型:

package cn.juwatech.example;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
@Document(indexName = "my_index", type = "my_type")
public class Book {
    @Id
    private String id;
    private String title;
    private String author;
    // Getters and setters
    // Constructors
    // Other fields and methods
}

在这个例子中,我们定义了一个简单的Book类,使用了@Document注解来指定索引名称和文档类型,@Id注解表示文档的唯一标识。

编写Repository接口

接下来,创建一个继承自ElasticsearchRepository的接口来操作Elasticsearch中的数据:

package cn.juwatech.example;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;
import java.util.List;
public interface BookRepository extends ElasticsearchRepository<Book, String> {
    List<Book> findByTitle(String title);
    List<Book> findByAuthor(String author);
}

通过继承ElasticsearchRepository接口,我们可以方便地进行索引数据的增删改查操作。

使用示例

添加数据

现在,让我们来看一个简单的示例,如何向Elasticsearch中添加数据:

package cn.juwatech.example;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
@Component
public class BookService {
    @Autowired
    private BookRepository bookRepository;
    public void addBook() {
        Book book = new Book();
        book.setId("1");
        book.setTitle("Spring Boot in Action");
        book.setAuthor("Craig Walls");
        bookRepository.save(book);
    }
}

在这个例子中,我们通过BookService将一本书保存到Elasticsearch中。

查询数据

接下来,我们来查询Elasticsearch中的数据:

package cn.juwatech.example;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.List;
@Component
public class BookSearchService {
    @Autowired
    private BookRepository bookRepository;
    public List<Book> searchByTitle(String title) {
        return bookRepository.findByTitle(title);
    }
    public List<Book> searchByAuthor(String author) {
        return bookRepository.findByAuthor(author);
    }
}

这里,我们创建了一个BookSearchService来进行按标题和作者的搜索操作。

总结

通过本文的教程,我们学习了如何在Spring Boot应用中集成Elasticsearch,并通过实例代码展示了基本的数据操作和搜索功能。从配置依赖、连接Elasticsearch,到定义实体类和操作Repository,我们覆盖了整个集成和使用过程。

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。 &nbsp;
相关文章
存储 JSON Java
658 0
|
9月前
|
安全 Java Linux
Linux安装Elasticsearch详细教程
Linux安装Elasticsearch详细教程
1791 64
|
11月前
|
人工智能 运维 自然语言处理
Elasticsearch AI Assistant 集成 DeepSeek,1分钟搭建智能运维助手
Elasticsearch 新支持 DeepSeek 系列模型,使用 AI 助手,通过自然语言交互,为可观测性分析、安全运维管理及数据智能处理提供一站式解决方案。
1281 3
Elasticsearch AI Assistant 集成 DeepSeek,1分钟搭建智能运维助手
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
614 2
|
JSON Java API
springboot集成ElasticSearch使用completion实现补全功能
springboot集成ElasticSearch使用completion实现补全功能
256 1
|
开发框架 监控 搜索推荐
GoFly快速开发框架集成ZincSearch全文搜索引擎 - Elasticsearch轻量级替代为ZincSearch全文搜索引擎
本文介绍了在项目开发中使用ZincSearch作为全文搜索引擎的优势,包括其轻量级、易于安装和使用、资源占用低等特点,以及如何在GoFly快速开发框架中集成和使用ZincSearch,提供了详细的开发文档和实例代码,帮助开发者高效地实现搜索功能。
835 0
|
Java Spring
解决Springboot集成ElasticSearch 报错:A bean with that name has already been defined in null and overriding
解决Springboot集成ElasticSearch 报错:A bean with that name has already been defined in null and overriding
510 2
|
搜索推荐 Java 数据库
springboot集成ElasticSearch的具体操作(系统全文检索)
springboot集成ElasticSearch的具体操作(系统全文检索)
|
Java 测试技术 Maven
SpringBoot集成Elasticsearch
SpringBoot集成Elasticsearch
409 0