【SpringBoot中怎么使用ElasticSearch】

springboot中怎么使用ElasticSearch

在Spring Boot中使用ElasticSearch,可以通过集成Spring Data ElasticSearch来实现。以下是一个详细的步骤指南,帮助你设置和使用ElasticSearch与Spring Boot。

1. 添加依赖

首先,在你的Spring Boot项目的pom.xml文件中添加Spring Data ElasticSearch的依赖。

xml 复制代码
<dependencies>
    <!-- Spring Boot Starter Data ElasticSearch -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
    </dependency>
    
    <!-- 如果使用Java REST High Level Client,可以添加这个依赖 -->
    <dependency>
        <groupId>org.elasticsearch.client</groupId>
        <artifactId>elasticsearch-rest-high-level-client</artifactId>
        <version>7.10.2</version> <!-- 确保版本与你的ElasticSearch服务器匹配 -->
    </dependency>
    
    <!-- 其他依赖 -->
</dependencies>

2. 配置ElasticSearch

application.propertiesapplication.yml中配置ElasticSearch的连接信息。

properties 复制代码
# application.properties
spring.elasticsearch.rest.uris=http://localhost:9200

或者

yaml 复制代码
# application.yml
spring:
  elasticsearch:
    rest:
      uris: http://localhost:9200

3. 创建实体类

创建一个实体类,并使用Spring Data ElasticSearch的注解来映射ElasticSearch的索引和文档。

java 复制代码
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
 
@Document(indexName = "my-index")
public class MyEntity {
 
    @Id
    private String id;
    private String name;
    private String description;
 
    // Getters and Setters
}

4. 创建Repository接口

创建一个继承自ElasticsearchRepository的接口,用于数据访问。

java 复制代码
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;
 
public interface MyEntityRepository extends ElasticsearchRepository<MyEntity, String> {
    // 自定义查询方法可以在这里定义,如果需要的话
}

5. 使用Service和Controller

在Service中注入Repository,并编写业务逻辑。

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
 
import java.util.List;
 
@Service
public class MyEntityService {
 
    @Autowired
    private MyEntityRepository repository;
 
    public List<MyEntity> findAll() {
        return repository.findAll();
    }
 
    public MyEntity save(MyEntity entity) {
        return repository.save(entity);
    }
 
    // 其他业务逻辑
}

在Controller中调用Service,并处理HTTP请求。

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
 
import java.util.List;
 
@RestController
@RequestMapping("/my-entities")
public class MyEntityController {
 
    @Autowired
    private MyEntityService service;
 
    @GetMapping
    public List<MyEntity> getAllEntities() {
        return service.findAll();
    }
 
    @PostMapping
    public MyEntity createEntity(@RequestBody MyEntity entity) {
        return service.save(entity);
    }
 
    // 其他HTTP处理方法
}

6. 启动应用程序

确保ElasticSearch服务器正在运行,然后启动你的Spring Boot应用程序。你现在应该能够通过HTTP请求与ElasticSearch进行交互。

7. 测试

你可以使用Postman或curl来测试你的API。例如,创建一个新的实体:

bash 复制代码
curl -X POST "http://localhost:8080/my-entities" -H "Content-Type: application/json" -d '{
    "id": "1",
    "name": "Test Entity",
    "description": "This is a test entity."
}'

获取所有实体:

bash 复制代码
bash复制代码

curl -X GET "http://localhost:8080/my-entities"

这样,你就完成了在Spring Boot中集成和使用ElasticSearch的基本步骤。如果需要更高级的功能,比如自定义查询、分页、排序等,可以参考Spring Data ElasticSearch的官方文档。或者这个文档https://blog.csdn.net/ZGL_cyy/article/details/112796302

相关推荐
muyun28008 小时前
Docker 下部署 Elasticsearch 8 并集成 Kibana 和 IK 分词器
elasticsearch·docker·容器
麦兜*8 小时前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud
麦兜*8 小时前
MongoDB 在物联网(IoT)中的应用:海量时序数据处理方案
java·数据库·spring boot·物联网·mongodb·spring
汤姆yu8 小时前
基于springboot的毕业旅游一站式定制系统
spring boot·后端·旅游
计算机毕业设计木哥9 小时前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计
在未来等你15 小时前
Elasticsearch面试精讲 Day 17:查询性能调优实践
大数据·分布式·elasticsearch·搜索引擎·面试
hdsoft_huge18 小时前
Java & Spring Boot常见异常全解析:原因、危害、处理与防范
java·开发语言·spring boot
全栈工程师修炼指南21 小时前
告别手动构建!Jenkins 与 Gitlab 完美协作,根据参数自动化触发CI/CD流水线实践
运维·ci/cd·自动化·gitlab·jenkins
AD钙奶-lalala21 小时前
SpringBoot实现WebSocket服务端
spring boot·后端·websocket
毕设源码-朱学姐1 天前
【开题答辩全过程】以 4S店汽车维修保养管理系统为例,包含答辩的问题和答案
java·spring boot·汽车