springboot 整合es

Spring Boot可以轻松地与Elasticsearch进行整合,以实现高效的搜索和分析功能。

以下是如何在Spring Boot应用程序中使用Elasticsearch的步骤:

1.添加依赖项

pom.xml文件中添加以下依赖项:

复制代码
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

2.配置Elasticsearch

在Spring Boot应用程序的配置文件application.properties中添加以下配置:

复制代码
spring.data.elasticsearch.cluster-name=elasticsearch
spring.data.elasticsearch.cluster-nodes=localhost:9300

这里假设您正在运行Elasticsearch节点,该节点位于本地主机上的端口9300。

3.创建Elasticsearch存储库

创建一个包含所有必需方法的Elasticsearch存储库接口。例如:

复制代码
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;

public interface ProductRepository extends ElasticsearchRepository<Product, Long> {
}

4.定义数据模型

定义与Elasticsearch文档相对应的数据模型。例如,以下是一个名为"Product"的类:

复制代码
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;

@Document(indexName = "products", type = "product")
public class Product {
   @Id
   private String id;
   private String name;
   private String description;
   private double price;
   // getters and setters
}

5.使用存储库

在Spring Boot应用程序的服务层中使用存储库进行搜索和保存数据。例如:

复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class ProductService {
   @Autowired
   private ProductRepository productRepository;

   public Iterable<Product> searchByName(String name) {
      return productRepository.findByName(name);
   }

   public void save(Product product) {
      productRepository.save(product);
   }
}

6.测试您的应用程序

您现在可以启动您的Spring Boot应用程序并测试它是否可以与Elasticsearch集成。例如,您可以像以下方式搜索产品:

复制代码
@Autowired
private ProductService productService;

@GetMapping("/search")
public List<Product> search(@RequestParam String name) {
   Iterable<Product> products = productService.searchByName(name);
   List<Product> productList = new ArrayList<>();
   products.forEach(productList::add);
   return productList;
}

此外,您还可以使用Elasticsearch的REST API测试您的应用程序。例如,您可以通过以下方式创建一个名为"Product"的索引:

复制代码
PUT /products
{
   "settings": {
      "number_of_shards": 1
   },
   "mappings": {
      "product": {
         "properties": {
            "name": {
               "type": "text"
            },
            "description": {
               "type": "text"
            },
            "price": {
               "type": "double"
            }
         }
      }
   }
}

然后,您可以向"Product"索引添加文档:

复制代码
POST /products/product
{
   "name": "iPhone X",
   "description": "Apple iPhone",
   "price": 999.99
}
相关推荐
五阿哥永琪4 分钟前
基于Spring Boot + Redis Pub/Sub 实现跨实例SSE消息推送
spring boot·redis·bootstrap
RNEA ESIO9 分钟前
Redis四种模式在Spring Boot框架下的配置
spring boot·redis·bootstrap
pupudawang16 分钟前
Spring Boot 热部署
java·spring boot·后端
SiYuanFeng17 分钟前
新手学Git:以一个小游戏项目为例,完成初始化、提交、查看历史与恢复版本
大数据·git·elasticsearch
我登哥MVP19 分钟前
【SpringMVC笔记】 - 9 - 异常处理器
java·spring boot·spring·servlet·tomcat·maven
下地种菜小叶24 分钟前
Spring Boot 2.x 升级 3.x / 4.x 怎么做?一次讲清 JDK、Jakarta、依赖兼容与上线策略
java·spring boot·后端
有梦想的小何43 分钟前
`Java并发排障实录:没有报错,却把正确数据覆盖错了`
java·spring boot·mysql·spring cloud
何妨呀~1 小时前
Subversion与Jenkins自动化平台
运维·自动化·jenkins
superantwmhsxx1 小时前
Spring Initializr创建springboot项目,提示java 错误 无效的源发行版:16
java·spring boot·spring
计算机毕业设计指导1 小时前
基于SpringBoot+Vue3的荣成市健康管理平台设计与实现
java·spring boot·后端