Elasticsearch集成到Spring Boot项目

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: 将Elasticsearch集成到Spring Boot项目中,可以方便地实现数据的搜索、分析等功能。

在Java开发中,Elasticsearch(ES)是一个非常受欢迎的分布式搜索引擎,而Spring Boot则是简化Spring应用初始搭建以及开发过程的一个框架。将Elasticsearch集成到Spring Boot项目中,可以方便地实现数据的搜索、分析等功能。下面是一个简单的示例,展示如何在Spring Boot应用中使用Elasticsearch。

环境准备

  1. Java环境:确保你有Java Development Kit (JDK) 8或更高版本。
  2. Maven或Gradle:本示例使用Maven作为构建工具。
  3. Elasticsearch:安装并运行Elasticsearch。可以在官方下载页面获取最新版本。
  4. Spring Boot:建议使用Spring Initializr来快速创建项目,或手动配置依赖。

创建Spring Boot项目

使用Spring Initializr(访问https://start.spring.io/),选择所需的依赖项,包括:

  • Web:用于启用Web支持。
  • Elasticsearch:自动添加Elasticsearch客户端依赖。

或者,如果你手动编辑pom.xml,添加以下依赖:

Xml

1<dependencies>
2    <dependency>
3        <groupId>org.springframework.boot</groupId>
4        <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
5    </dependency>
6    <dependency>
7        <groupId>org.springframework.boot</groupId>
8        <artifactId>spring-boot-starter-web</artifactId>
9    </dependency>
10</dependencies>

配置Elasticsearch

application.propertiesapplication.yml中配置Elasticsearch连接信息:

Yaml

1spring.data.elasticsearch.cluster-name=your-cluster-name
2spring.data.elasticsearch.cluster-nodes=your-es-node-host:your-port

定义实体类

以一个简单的User实体为例:

Java

1import org.springframework.data.annotation.Id;
2import org.springframework.data.elasticsearch.annotations.Document;
3
4@Document(indexName = "user")
5public class User {
6    @Id
7    private String id;
8    private String name;
9    private String email;
10
11    // 构造函数、getters、setters省略
12}

创建Repository接口

继承ElasticsearchRepository来定义数据访问接口:

Java

1import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;
2
3public interface UserRepository extends ElasticsearchRepository<User, String> {
4}

编写服务类

创建一个服务类来处理业务逻辑,如保存和查询用户:

Java

1import org.springframework.beans.factory.annotation.Autowired;
2import org.springframework.stereotype.Service;
3
4@Service
5public class UserService {
6    private final UserRepository userRepository;
7
8    @Autowired
9    public UserService(UserRepository userRepository) {
10        this.userRepository = userRepository;
11    }
12
13    public User save(User user) {
14        return userRepository.save(user);
15    }
16
17    public Iterable<User> findAll() {
18        return userRepository.findAll();
19    }
20}

控制器类

最后,创建一个控制器类来处理HTTP请求:

Java

1import org.springframework.beans.factory.annotation.Autowired;
2import org.springframework.web.bind.annotation.*;
3
4@RestController
5@RequestMapping("/users")
6public class UserController {
7    private final UserService userService;
8
9    @Autowired
10    public UserController(UserService userService) {
11        this.userService = userService;
12    }
13
14    @PostMapping
15    public User createUser(@RequestBody User user) {
16        return userService.save(user);
17    }
18
19    @GetMapping
20    public Iterable<User> getAllUsers() {
21        return userService.findAll();
22    }
23}

运行和测试

  • 启动你的Spring Boot应用。
  • 使用Postman或类似工具向http://localhost:8080/users发送POST请求,添加用户数据。
  • 发送GET请求到http://localhost:8080/users来获取所有用户数据,验证数据是否被正确索引。

以上就是一个基本的Spring Boot集成Elasticsearch的示例。根据实际需求,你可以扩展功能,比如添加复杂的查询、分页、排序

相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
目录
相关文章
|
19天前
|
Java 应用服务中间件
SpringBoot获取项目文件的绝对路径和相对路径
SpringBoot获取项目文件的绝对路径和相对路径
56 1
SpringBoot获取项目文件的绝对路径和相对路径
|
9天前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
21 2
|
14天前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
36 8
|
21天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
40 2
|
21天前
|
前端开发 Java Spring
SpringBoot项目thymeleaf页面支持词条国际化切换
SpringBoot项目thymeleaf页面支持词条国际化切换
50 2
|
21天前
|
JSON Java 数据库
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
34 1
|
23天前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
24天前
|
JSON Java API
springboot集成ElasticSearch使用completion实现补全功能
springboot集成ElasticSearch使用completion实现补全功能
24 1
|
5天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
18 0
|
23天前
|
关系型数据库 MySQL Java
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
24 0

热门文章

最新文章

下一篇
无影云桌面