摘要:高級客戶端目前支持更常用的,但還有很多東西需要補充,您可以通過告訴我們您的應用程序需要哪些缺失的來幫助我們優化優先級,通過向這個添加注釋高級客戶端完整性。傳輸客戶端排除非數據節點的原因是為了避免將搜索流量發送給主節點。
前言
本節描述了Elasticsearch提供的Java API,所有的Elasticsearch操作都使用客戶端對象執行,所有操作本質上都是完全異步的(要么接收監聽器,要么未來返回)。
此外,客戶端上的操作可能會大量累積和執行。
注意,所有的API都是通過Java API公開的(實際上,Java API是在內部使用以執行它們的)。
警告Javadoc
我們計劃在Elasticsearch 7.0中對TransportClient進行棄用,并在8.0中完全刪除它,替而代之,你應該使用Java高級REST客戶端,它執行HTTP請求而不是序列化的Java請求。遷移指南描述了遷移所需的所有步驟。Java高級REST客戶端目前支持更常用的API,但還有很多東西需要補充,您可以通過告訴我們您的應用程序需要哪些缺失的API來幫助我們優化優先級,通過向這個issue添加注釋:Java高級REST客戶端完整性。
任何丟失的API都可以通過使用具有JSON請求和響應主體的低級Java REST客戶端來實現。
transport client的javadoc可以在這里找到:https://artifacts.elastic.co/...。
Maven存儲庫Elasticsearch駐留在Maven Central上。
例如,您可以在pom.xml文件中定義最新的版本:
Lucene Snapshot存儲庫org.elasticsearch.client transport 6.2.4
任何主要版本(如beta)的第一個releases版本都可能構建在Lucene Snapshot版本之上,在這種情況下,您將無法解析客戶端的Lucene依賴項。
例如,如果您想使用基于Lucene 7.0.0-snapshot-00142c9的6.0.0-beta1版本,您必須定義以下存儲庫。
Maven:
elastic-lucene-snapshots Elastic Lucene Snapshots http://s3.amazonaws.com/download.elasticsearch.org/lucenesnapshots/00142c9 true false
Gradle:
maven { url "http://s3.amazonaws.com/download.elasticsearch.org/lucenesnapshots/00142c9" }Log4j 2記錄器
您還需要包括Log4j 2依賴項:
org.apache.logging.log4j log4j-core 2.9.1
并在類路徑中提供Log4j 2配置文件,例如,你可以給你的src/main/resources工程目錄添加一個log4j2.properties文件,像這樣:
appender.console.type = Console appender.console.name = console appender.console.layout.type = PatternLayout rootLogger.level = info rootLogger.appenderRef.console.ref = console使用另一個記錄器
如果你想使用另一個日志記錄器,而不是Log4j 2,你可以使用SLF4J bridge來實現這一點:
org.apache.logging.log4j log4j-to-slf4j 2.9.1 org.slf4j slf4j-api 1.7.24
這個頁面列出了可以使用的實現,選擇您最喜歡的日志記錄器,并將其作為依賴項添加。例如,我們將使用slf4j-simple 日志記錄器:
java客戶端org.slf4j slf4j-simple 1.7.21
你可以通過多種方式使用Java客戶端:
在現有集群上執行標準索引、獲取、刪除和搜索操作
在運行的集群上執行管理任務
獲取一個Elasticsearch客戶端很簡單,獲取客戶端最常見的方法是創建一個連接到集群的TransportClient。
重要
客戶端必須具有與集群中的節點相同的主版本(例如,2.x,或5.x),客戶端可能連接到具有不同次要版本的集群(例如2.3.x),但可能不支持新功能,理想情況下,客戶端應該具有與集群相同的版本。
警告傳輸客戶端
我們計劃在Elasticsearch 7.0中對TransportClient進行棄用,并在8.0中完全刪除它,替而代之,你應該使用Java高級REST客戶端,它執行HTTP請求而不是序列化的Java請求。遷移指南描述了遷移所需的所有步驟。Java高級REST客戶端目前支持更常用的API,但還有很多東西需要補充,您可以通過告訴我們您的應用程序需要哪些缺失的API來幫助我們優化優先級,通過向這個issue添加注釋:Java高級REST客戶端完整性。
任何丟失的API都可以通過使用具有JSON請求和響應主體的低級Java REST客戶端來實現。
TransportClient使用傳輸模塊遠程連接到Elasticsearch集群,它不加入集群,但只需獲取一個或多個初始傳輸地址,并在每個操作上以循環的方式與它們通信(盡管大多數操作可能是“兩跳”操作)。
// on startup TransportClient client = new PreBuiltTransportClient(Settings.EMPTY) .addTransportAddress(new TransportAddress(InetAddress.getByName("host1"), 9300)) .addTransportAddress(new TransportAddress(InetAddress.getByName("host2"), 9300)); // on shutdown client.close();
注意,如果你使用的是與“elasticsearch”不同的集群名稱,則必須設置集群名稱:
Settings settings = Settings.builder() .put("cluster.name", "myClusterName").build(); TransportClient client = new PreBuiltTransportClient(settings); //Add transport addresses and do something with the client...
傳輸客戶端具有集群嗅探特性,允許動態添加新主機并刪除舊主機,當啟用嗅探時,傳輸客戶機將連接到其內部節點列表中的節點,這些節點是通過調用addTransportAddress構建的。在此之后,客戶端將調用這些節點上的內部集群狀態API來發現可用的數據節點,客戶端的內部節點列表將僅用這些數據節點替換,默認情況下,這個列表每5秒刷新一次。注意,嗅探器連接的IP地址是在這些節點的Elasticsearch配置中聲明為發布的地址。
請記住,如果該節點不是一個數據節點,該列表可能不包括它連接到的原始節點。例如,如果您最初連接到一個主節點,在嗅探之后,沒有進一步的請求將進入主節點,而是指向任何數據節點。傳輸客戶端排除非數據節點的原因是為了避免將搜索流量發送給主節點。
為了啟用嗅探,請設置client.transport.sniff為true:
Settings settings = Settings.builder() .put("client.transport.sniff", true).build(); TransportClient client = new PreBuiltTransportClient(settings);
其他傳輸客戶端級別設置包括:
參數:client.transport.ignore_cluster_name
描述:設置為true以忽略連接節點的集群名稱驗證。(自從0.19.4)
參數:client.transport.ping_timeout
描述:等待節點的ping響應的時間,默認為5s。
參數:client.transport.nodes_sampler_interval
描述:采樣/ping節點登記和連接的頻率,默認5s。
將客戶端連接到僅協調的節點您可以在本地啟動一個只協調的節點,然后在應用程序中創建一個TransportClient,該客戶端連接到這個只協調的節點。
通過這種方式,只需協調的節點將能夠加載您需要的任何插件(例如,關于discovery插件)。
下一篇:Elasticsearch Java API 6.2(文檔API)文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/69699.html
摘要:注意當一個文檔在快照的時間和索引請求過程之間發生變化時,會發生版本沖突。當版本匹配時,更新文檔并增加版本號。在正在運行的更新中,使用更改的值使用查找的值。值加快進程立即生效,減慢查詢的值在完成當前批處理后生效,以防止滾動超時。 文檔API 本節描述以下CRUD API: 單文檔的API Index API Get API Delete API Update API 多文檔API ...
摘要:入門本節描述從獲取工件到在應用程序中使用它如何開始使用高級別客戶端。保證能夠與運行在相同主版本和大于或等于的次要版本上的任何節點通信。與具有相同的發布周期,將版本替換為想要的客戶端版本。 Java High Level REST Client 入門 本節描述從獲取工件到在應用程序中使用它如何開始使用高級別REST客戶端。 兼容性 Java High Level REST Client需...
閱讀 2112·2021-11-23 09:51
閱讀 3708·2021-10-20 13:49
閱讀 1715·2021-09-06 15:13
閱讀 1827·2021-09-06 15:02
閱讀 3174·2021-09-02 15:11
閱讀 897·2019-08-29 15:37
閱讀 1742·2019-08-29 13:24
閱讀 2280·2019-08-29 11:28