elasticsearch?java客戶端action的實現簡單分析
上一篇介紹了elasticsearch的client結構,client只是一個門面,在每個方法后面都有一個action來承接相應的功能。但是action也并非是真正的功能實現者,它只是一個代理,它的真正實現者是transportAction.本篇就對action及transportAction的實現做一個簡單的分析,
elasticsearch中的絕大部分操作都是通過相應的action,這些action在action包中。它的結構如下圖所示:

上圖是action包的部分截圖,這里面對應著各個功能的action。各個action的包也都非常類似于index。這些action的實現也非常類似,都是基礎自action,下圖是indexaction的繼承關系:

因為這些action并未真正實現相應的功能,只是一個代理,因此實現上也非常簡單。他們的主要作用是提供新建response和request的方法及對應的action名稱。還拿indexaction為例,它的方法圖如下所示:

可以看到它只是提供了兩個新建response和request的方法,及一個字NAME字段,這個NAME字段會用于后面action調用中。每個action對應的功能實現是在對應的transportAction中。

這些tansportAction都繼承了TransportAction接口??蛻舳苏{用client的相關接口時,client會將請求發(fā)送到transportAction的execute上。每個功能的TransportAction實現了doExecute方法,功能的邏輯都在此方法中實現,這里先暫且不提,后面的功能分析中會看到對應的實現。
在client分析中有這樣一段代碼:
TransportAction<Request, Response> transportAction = actions.get((ClientAction)action)它的作用就是根據action獲取TransportAction。因為action只是代理。這些關聯(lián)關系是在ActionModule中實現的,代碼如下所示:
registerAction(NodesInfoAction.INSTANCE, TransportNodesInfoAction.class);
registerAction(NodesStatsAction.INSTANCE, TransportNodesStatsAction.class);
registerAction(NodesShutdownAction.INSTANCE, TransportNodesShutdownAction.class);
registerAction(NodesRestartAction.INSTANCE, TransportNodesRestartAction.class);
registerAction(NodesHotThreadsAction.INSTANCE, TransportNodesHotThreadsAction.class);
registerAction(ClusterStatsAction.INSTANCE, TransportClusterStatsAction.class);
registerAction(ClusterStateAction.INSTANCE, TransportClusterStateAction.class);
registerAction(ClusterHealthAction.INSTANCE, TransportClusterHealthAction.class)這只是一小部分,可以看到在module中會將對應的action和TransportAction綁定。這樣在client需要收到請求時會根據對于的action實例來查找對應的tansportAction實例,最終請求在它們下面處理。
總結:這里對action及TransportAction做了簡單分析。作為elasticsearch對外的java客戶端的一部分,action作用是在客戶端相應的方法中接收相應的請求,然后轉發(fā)到對應的TransportAction中進行處理。這里使用了代理模式,通過guice注入解耦。
以上就是elasticsearch java客戶端action的實現簡單分析的詳細內容,更多關于elasticsearch java客戶端action實現的資料請關注腳本之家其它相關文章!
相關文章
Flink實現特定統(tǒng)計的歸約聚合reduce操作
這篇文章主要介紹了Flink實現特定統(tǒng)計的歸約聚合reduce操作,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2023-02-02
springboot使用shiro-整合redis作為緩存的操作
這篇文章主要介紹了springboot使用shiro-整合redis作為緩存的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
Java 使用POI生成帶聯(lián)動下拉框的excel表格實例代碼
本文通過實例代碼給大家分享Java 使用POI生成帶聯(lián)動下拉框的excel表格,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2017-09-09
Maven方式構建SpringBoot項目的實現步驟(圖文)
Maven是一個強大的項目管理工具,可以幫助您輕松地構建和管理Spring Boot應用程序,本文主要介紹了Maven方式構建SpringBoot項目的實現步驟,具有一定的參考價值,感興趣的可以了解一下2023-09-09

