新版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客戶端。
上述演示項目源代碼獲取地址: