欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

elasticsearch?java客戶端action的實現(xiàn)簡單分析

 更新時間:2022年04月21日 17:00:02   作者:zziawan  
這篇文章主要為大家介紹了elasticsearch?java客戶端action的實現(xiàn)簡單分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

上一篇介紹了elasticsearch的client結(jié)構(gòu),client只是一個門面,在每個方法后面都有一個action來承接相應(yīng)的功能。但是action也并非是真正的功能實現(xiàn)者,它只是一個代理,它的真正實現(xiàn)者是transportAction.本篇就對action及transportAction的實現(xiàn)做一個簡單的分析,

elasticsearch中的絕大部分操作都是通過相應(yīng)的action,這些action在action包中。它的結(jié)構(gòu)如下圖所示:

上圖是action包的部分截圖,這里面對應(yīng)著各個功能的action。各個action的包也都非常類似于index。這些action的實現(xiàn)也非常類似,都是基礎(chǔ)自action,下圖是indexaction的繼承關(guān)系:

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

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

這些tansportAction都繼承了TransportAction接口。客戶端調(diào)用client的相關(guān)接口時,client會將請求發(fā)送到transportAction的execute上。每個功能的TransportAction實現(xiàn)了doExecute方法,功能的邏輯都在此方法中實現(xiàn),這里先暫且不提,后面的功能分析中會看到對應(yīng)的實現(xiàn)。

在client分析中有這樣一段代碼:

TransportAction<Request, Response> transportAction = actions.get((ClientAction)action)它的作用就是根據(jù)action獲取TransportAction。因為action只是代理。這些關(guān)聯(lián)關(guān)系是在ActionModule中實現(xiàn)的,代碼如下所示:

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中會將對應(yīng)的action和TransportAction綁定。這樣在client需要收到請求時會根據(jù)對于的action實例來查找對應(yīng)的tansportAction實例,最終請求在它們下面處理。

總結(jié):這里對action及TransportAction做了簡單分析。作為elasticsearch對外的java客戶端的一部分,action作用是在客戶端相應(yīng)的方法中接收相應(yīng)的請求,然后轉(zhuǎn)發(fā)到對應(yīng)的TransportAction中進行處理。這里使用了代理模式,通過guice注入解耦。

以上就是elasticsearch java客戶端action的實現(xiàn)簡單分析的詳細內(nèi)容,更多關(guān)于elasticsearch java客戶端action實現(xiàn)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Flink實現(xiàn)特定統(tǒng)計的歸約聚合reduce操作

    Flink實現(xiàn)特定統(tǒng)計的歸約聚合reduce操作

    這篇文章主要介紹了Flink實現(xiàn)特定統(tǒng)計的歸約聚合reduce操作,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02
  • java多線程從入門到精通看這篇就夠了

    java多線程從入門到精通看這篇就夠了

    熟悉 Java 多線程編程的同學(xué)都知道,當(dāng)我們線程創(chuàng)建過多時,容易引發(fā)內(nèi)存溢出,因此我們就有必要使用線程池的技術(shù)了,今天通過本文給大家分享java多線程從入門到精通的相關(guān)知識,一起看看吧
    2021-06-06
  • Spring中使用事務(wù)嵌套時需要警惕的問題分享

    Spring中使用事務(wù)嵌套時需要警惕的問題分享

    最近項目上有一個使用事務(wù)相對復(fù)雜的業(yè)務(wù)場景報錯了。在絕大多數(shù)情況下,都是風(fēng)平浪靜,沒有問題。其實內(nèi)在暗流涌動,在有些異常情況下就會報錯,這種偶然性的問題很有可能就會在暴露到生產(chǎn)上造成事故,那究竟是怎么回事呢?本文就來簡單講講
    2023-04-04
  • springboot使用shiro-整合redis作為緩存的操作

    springboot使用shiro-整合redis作為緩存的操作

    這篇文章主要介紹了springboot使用shiro-整合redis作為緩存的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • MyBatis緩存實現(xiàn)原理及代碼實例解析

    MyBatis緩存實現(xiàn)原理及代碼實例解析

    這篇文章主要介紹了MyBatis緩存實現(xiàn)原理及代碼實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • 深入解析JVM對dll文件和對類的裝載過程

    深入解析JVM對dll文件和對類的裝載過程

    這篇文章主要介紹了JVM對dll文件的裝載和對類的裝載過程,針對Java在Windows下的一些運行情況作出講解,需要的朋友可以參考下
    2015-11-11
  • Java 使用POI生成帶聯(lián)動下拉框的excel表格實例代碼

    Java 使用POI生成帶聯(lián)動下拉框的excel表格實例代碼

    本文通過實例代碼給大家分享Java 使用POI生成帶聯(lián)動下拉框的excel表格,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-09-09
  • Maven方式構(gòu)建SpringBoot項目的實現(xiàn)步驟(圖文)

    Maven方式構(gòu)建SpringBoot項目的實現(xiàn)步驟(圖文)

    Maven是一個強大的項目管理工具,可以幫助您輕松地構(gòu)建和管理Spring Boot應(yīng)用程序,本文主要介紹了Maven方式構(gòu)建SpringBoot項目的實現(xiàn)步驟,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • spring多個事務(wù)管理器踩坑及解決

    spring多個事務(wù)管理器踩坑及解決

    這篇文章主要介紹了spring多個事務(wù)管理器踩坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Java設(shè)計模式之單例模式簡單解析

    Java設(shè)計模式之單例模式簡單解析

    這篇文章主要介紹了Java設(shè)計模式之單例模式簡單解析,單例模式的優(yōu)點在于在內(nèi)存中某個類只有一個實例,減少了內(nèi)存的開銷,尤其是頻繁的創(chuàng)建和銷毀實例,避免對資源的多重暫用,需要的朋友可以參考下
    2023-12-12

最新評論