<dubbo:annotation >配置 —— 分庫遇到問題(2)

在上篇筆記《<context:component-scan> 配置 —— 分庫遇到問題(1)》中解決了 spring中某些實(shí)例被初始化了兩次的問題,
但是緊接著又來了另一個(gè)頭疼的問題,dubbo的@Reference為null無法注入 !
Controller層的注解正常?。?/p>

<dubbo:annotation />
    <context:component-scan base-package="xxx" use-default-filters="false">
        <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
        <context:include-filter type="annotation" expression="org.springframework.web.bind.annotation.RestController" />
    </context:component-scan>

我把這個(gè)問題提出來之后,大家都提出來,在dubbo的service或者spring還沒有初始化完成之前就開始掃描 @Reference導(dǎo)致取到null值。但是怎么去找到問題的根源呢?
于是幾個(gè)人在一塊排查,剛開始是修改spring的配置文件。把有關(guān)掃描的配置重新檢查了一下,并沒有發(fā)現(xiàn)問題。網(wǎng)上查關(guān)于dubbo初始化的資料,依然沒有發(fā)現(xiàn)解決問題的方法!
查詢無果后,開始往源碼上面去研究。
我始終在想,之前dubbo使用沒有問題的,就在我昨天加了use-default-filters="false"才出現(xiàn)的這個(gè)問題,所以我圍繞著 context:component-scan + dubbo:annotation尋找答案,其中一條結(jié)果是指向 Dubbo的官方文檔。如下:

服務(wù)提供方注解:

import com.alibaba.dubbo.config.annotation.Service;
@Service(version="1.0.0")
public class FooServiceImpl implements FooService {
}

服務(wù)提供方配置:

<!-- 公共信息,也可以用dubbo.properties配置 -->
<dubbo:application name="annotation-provider" />
<dubbo:registry address="127.0.0.1:4548" />
<!-- 掃描注解包路徑,多個(gè)包用逗號(hào)分隔,不填pacakge表示掃描當(dāng)前ApplicationContext中所有的類 -->
<dubbo:annotation package="com.foo.bar.service" />

服務(wù)消費(fèi)方注解:

import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Component;
@Component
public class BarAction {
    @Reference(version="1.0.0")
    private FooService fooService;
}

服務(wù)消費(fèi)方配置:

<!-- 公共信息,也可以用dubbo.properties配置 -->
<dubbo:application name="annotation-consumer" />
<dubbo:registry address="127.0.0.1:4548" />
<!-- 掃描注解包路徑,多個(gè)包用逗號(hào)分隔,不填pacakge表示掃描當(dāng)前ApplicationContext中所有的類 -->
<dubbo:annotation package="com.foo.bar.action" />

也可以使用:(等價(jià)于前面的:<dubbo:annotation package="com.foo.bar.service" />)

<dubbo:annotation />
<context:component-scan base-package="com.foo.bar.service">
    <context:include-filter type="annotation" expression="com.alibaba.dubbo.config.annotation.Service" />
</context:component-scan>

從官方給的樣例找到了問題產(chǎn)生的原因。dubbo:annotation不指定包名的話會(huì)在spring bean中查找對(duì)應(yīng)實(shí)例的類配置了dubbo注解的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,578評(píng)論 19 139
  • 上一篇:Spring學(xué)習(xí)筆記(四、Bean裝配(上)) 這篇講解Bean管理的注解實(shí)現(xiàn)及例子 主要內(nèi)容有: Cla...
    魯克巴克詩閱讀 1,337評(píng)論 2 6
  • 前記 近日完成一個(gè)采用dubbo完成分布式應(yīng)用項(xiàng)目,現(xiàn)記錄下一些dubbo使用的記錄,以備以后查詢使用。好記性不如...
    在路上_Rogge閱讀 574評(píng)論 0 1
  • 說想說的話,真實(shí)記自己的心理成長歷程,努力 做最真實(shí)的自己
    踏雪歸來思雪閱讀 189評(píng)論 0 0
  • 噫吁嚱,危乎高哉,理賠之難,難于上青天! 提及保險(xiǎn)理賠,一時(shí)興起,吟詩一首: 買保險(xiǎn)的時(shí)候你是大爺:干爹;理賠的時(shí)...
    雙棒fengtaisb閱讀 443評(píng)論 1 5

友情鏈接更多精彩內(nèi)容