新版Elasticsearch 7.3 和 Spring Boot 2.1.7 集成演示项目
第一个项目:演示Elasticsearch 6.4.3 和Spring Boot 2.1.7集成
基于spring-data-elasticsearch 组件,实现和Spring Boot 2.1.7的集成。
spring-data-elasticsearch 是 Spring Data 的 Community modules 之一,是 Spring Data 对 Elasticsearch 引擎的实现。Elasticsearch 默认提供轻量级的 HTTP Restful 接口形式的访问。相对来讲,使用 HTTP Client 调用也很简单。但 spring-data-elasticsearch 能够更快的支持构建在 Spring 应用上,好比在 application.properties 配置 Elaticsearch 节点信息和 spring-boot-starter-data-elasticsearch 依赖,直接在 Spring Boot 应用上使用。
该组件最大的问题是更新不及时,远远落后于Elasticsearch 发布的速度。
第二个项目:rest-client-demo
使用Java High Level REST Client操做elasticsearch。
如今Elasticsearch 官方推出Java High Level REST Client,它是基于Java Low Level REST Client的封装,而且API接收参数和返回值和TransportClient是同样的,使得代码迁移变得容易而且支持了RESTful的风格,兼容了这两种客户端的优势。固然缺点是存在的,就是版本的问题。Elasticsearch 的小版本更新很是频繁,在最理想的状况下,客户端的版本要和ES的版本一致(至少主版本号一致),次版本号不一致的话,基本操做也许能够,可是新API就不支持了。
目前比较推荐使用官方的高阶(High Level)Rest Client,Elasticsearch官方维护,比较值得信赖。
第三个项目:transport-client-demo
使用Java TransportClient 操做Elasticsearch(Spring Boot/Maven)。经过Transport Client来操做Elasticsearch,主要缘由是老版本的Elasticsearch 服务集群仍然会存在至关长一段时间,而且Java应用系统须要持续维护。
本文演示经过Transport Client来操做Elasticsearch。TransportClient 是一种轻量级的方法,它经过Socket与Elasticsearch集群链接,是基于Netty 线程池的方式。
TransportClient旨在被Java High-level REST client接口取代。 在 Elasticsearch 7.*版本中将不同意使用TransportClient,在Elasticsearch 8.0 版本中将被移除,建议使用Java High-level REST Client客户端。
上述演示项目源代码获取地址: