溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

dubbo的spi思想是什么

發(fā)布時間:2021-12-15 14:56:48 來源:億速云 閱讀:122 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“dubbo的spi思想是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“dubbo的spi思想是什么”吧!

spi 是啥?

spi,簡單來說,就是 service provider interface,說白了是什么意思呢,比如你有個接口,現(xiàn)在這個接口有 3 個實現(xiàn)類,那么在系統(tǒng)運行的時候?qū)@個接口到底選擇哪個實現(xiàn)類呢?這就需要 spi 了,需要根據(jù)指定的配置或者是默認的配置,去找到對應的實現(xiàn)類加載進來,然后用這個實現(xiàn)類的實例對象。

舉個栗子。

你有一個接口A。A1/A2/A3 分別是接口A的不同實現(xiàn)。你通過配置 接口A=實現(xiàn)A2,那么在系統(tǒng)實際運行的時候,會加載你的配置,用實現(xiàn)A2實例化一個對象來提供服務。

spi 機制一般用在哪兒?插件擴展的場景,比如說你開發(fā)了一個給別人使用的開源框架,如果你想讓別人自己寫個插件,插到你的開源框架里面,從而擴展某個功能,這個時候 spi 思想就用上了。

Java spi 思想的體現(xiàn)

spi 經(jīng)典的思想體現(xiàn),大家平時都在用,比如說 jdbc。

Java 定義了一套 jdbc 的接口,但是 Java 并沒有提供 jdbc 的實現(xiàn)類。

但是實際上項目跑的時候,要使用 jdbc 接口的哪些實現(xiàn)類呢?一般來說,我們要根據(jù)自己使用的數(shù)據(jù)庫,比如 mysql,你就將 mysql-jdbc-connector.jar 引入進來;oracle,你就將 oracle-jdbc-connector.jar 引入進來。

在系統(tǒng)跑的時候,碰到你使用 jdbc 的接口,他會在底層使用你引入的那個 jar 中提供的實現(xiàn)類。

dubbo 的 spi 思想

dubbo 也用了 spi 思想,不過沒有用 jdk 的 spi 機制,是自己實現(xiàn)的一套 spi 機制。

Protocol protocol = ExtensionLoader.getExtensionLoader(Protocol.class).getAdaptiveExtension();

Protocol 接口,在系統(tǒng)運行的時候,,dubbo 會判斷一下應該選用這個 Protocol 接口的哪個實現(xiàn)類來實例化對象來使用。

它會去找一個你配置的 Protocol,將你配置的 Protocol 實現(xiàn)類,加載到 jvm 中來,然后實例化對象,就用你的那個 Protocol 實現(xiàn)類就可以了。

上面那行代碼就是 dubbo 里大量使用的,就是對很多組件,都是保留一個接口和多個實現(xiàn),然后在系統(tǒng)運行的時候動態(tài)根據(jù)配置去找到對應的實現(xiàn)類。如果你沒配置,那就走默認的實現(xiàn)好了,沒問題。

@SPI("dubbo")  public interface Protocol {  
      
    int getDefaultPort();  
  
    @Adaptive  
    <T> Exporter<T> export(Invoker<T> invoker) throws RpcException;  
  
    @Adaptive  
    <T> Invoker<T> refer(Class<T> type, URL url) throws RpcException;  

    void destroy();  
  
}

在 dubbo 自己的 jar 里,在/META_INF/dubbo/internal/com.alibaba.dubbo.rpc.Protocol文件中:

dubbo=com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol
http=com.alibaba.dubbo.rpc.protocol.http.HttpProtocol
hessian=com.alibaba.dubbo.rpc.protocol.hessian.HessianProtocol

所以說,這就看到了 dubbo 的 spi 機制默認是怎么玩兒的了,其實就是 Protocol 接口,@SPI("dubbo") 說的是,通過 SPI 機制來提供實現(xiàn)類,實現(xiàn)類是通過 dubbo 作為默認 key 去配置文件里找到的,配置文件名稱與接口全限定名一樣的,通過 dubbo 作為 key 可以找到默認的實現(xiàn)類就是 com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol。

如果想要動態(tài)替換掉默認的實現(xiàn)類,需要使用 @Adaptive 接口,Protocol 接口中,有兩個方法加了 @Adaptive 注解,就是說那倆接口會被代理實現(xiàn)。

啥意思呢?

比如這個 Protocol 接口搞了倆 @Adaptive 注解標注了方法,在運行的時候會針對 Protocol 生成代理類,這個代理類的那倆方法里面會有代理代碼,代理代碼會在運行的時候動態(tài)根據(jù) url 中的 protocol 來獲取那個 key,默認是 dubbo,你也可以自己指定,你如果指定了別的 key,那么就會獲取別的實現(xiàn)類的實例了。

如何自己擴展 dubbo 中的組件

下面來說說怎么來自己擴展 dubbo 中的組件。

自己寫個工程,要是那種可以打成 jar 包的,里面的 src/main/resources 目錄下,搞一個 META-INF/services,里面放個文件叫:com.alibaba.dubbo.rpc.Protocol,文件里搞一個my=com.bingo.MyProtocol。自己把 jar 弄到 nexus 私服里去。

然后自己搞一個 dubbo provider 工程,在這個工程里面依賴你自己搞的那個 jar,然后在 spring 配置文件里給個配置:

<dubbo:protocol name=”my” port=”20000” />

provider 啟動的時候,就會加載到我們 jar 包里的my=com.bingo.MyProtocol 這行配置里,接著會根據(jù)你的配置使用你定義好的 MyProtocol 了,這個就是簡單說明一下,你通過上述方式,可以替換掉大量的 dubbo 內(nèi)部的組件,就是扔個你自己的 jar 包,然后配置一下即可。

dubbo的spi思想是什么

dubbo 里面提供了大量的類似上面的擴展點,就是說,你如果要擴展一個東西,只要自己寫個 jar,讓你的 consumer 或者是 provider 工程,依賴你的那個 jar,在你的 jar 里指定目錄下配置好接口名稱對應的文件,里面通過 key=實現(xiàn)類。

然后對于對應的組件,類似 <dubbo:protocol> 用你的那個 key 對應的實現(xiàn)類來實現(xiàn)某個接口,你可以自己去擴展 dubbo 的各種功能,提供你自己的實現(xiàn)。

到此,相信大家對“dubbo的spi思想是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI