您好,登錄后才能下訂單哦!
這篇文章主要介紹“怎么理解Spring Boot2中的Elasticsearch”,在日常操作中,相信很多人在怎么理解Spring Boot2中的Elasticsearch問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么理解Spring Boot2中的Elasticsearch”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
Elastic Search是一個開源的,分布式,實時搜索和分析引擎。Spring Boot為Elasticsearch提供基本的自動配置,Spring Data Elasticsearch提供在它之上的抽象,還有用于收集依賴的spring-boot-starter-data-elasticsearch’Starter’。
如果添加Jest依賴,你可以注入一個自動配置的JestClient,默認目標為http://localhost:9200/,也可以進一步配置該客戶端:
1spring.elasticsearch.jest.uris=http://search.example.com:9200
2spring.elasticsearch.jest.read-timeout=10000
3spring.elasticsearch.jest.username=user
4spring.elasticsearch.jest.password=secret
定義一個JestClient bean以完全控制注冊過程。
你可以注入一個自動配置的ElasticsearchTemplate或Elasticsearch Client實例,就想其他Spring Bean那樣。該實例默認內嵌一個本地,內存型服務器(在Elasticsearch中被稱為Node),并使用當前工作目錄作為服務器的home目錄。在這個步驟中,首先要做的是告訴Elasticsearch將文件存放到什么地方:
1spring.data.elasticsearch.properties.path.home=/foo/bar
另外,你可以通過設置spring.data.elasticsearch.cluster-nodes(逗號分隔的‘host:port’列表)來切換為遠程服務器:
1spring.data.elasticsearch.cluster-nodes=localhost:9300
1@Component
2public class MyBean {
3 private ElasticsearchTemplate template;
4 @Autowired
5 public MyBean(ElasticsearchTemplate template) {
6 this.template = template;
7 }
8 // ...
9}
如果添加自己的ElasticsearchTemplate類型的@Bean,它將覆蓋默認實例。
Spring Data包含的倉庫也支持Elasticsearch,正如前面討論的JPA倉庫,基于方法名自動創建查詢是基本的原則。
實際上,不管是Spring Data JPA還是Spring Data Elasticsearch都共享相同的基礎設施。所以你可以使用前面的JPA示例,并假設那個City現在是一個Elasticsearch @Document類而不是JPA @Entity,它將以同樣的方式工作。
到此,關于“怎么理解Spring Boot2中的Elasticsearch”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。