日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Dubbo 2.7應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)踩坑小記

 [[407480]]

背景

本文記錄最近一位讀者反饋的dubbo 2.7.x中應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)的問題,關(guān)于dubbo應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)的相關(guān)介紹可以參考之前的文章《dubbo應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)初體驗(yàn)》,這里不再贅述。

站在用戶的角度思考問題,與客戶深入溝通,找到冷水灘網(wǎng)站設(shè)計(jì)與冷水灘網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋冷水灘地區(qū)。

讀者反饋他們在基于dubbo 2.7應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)開發(fā)dubbo網(wǎng)關(guān),根據(jù)文章《dubbo應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)初體驗(yàn)》寫了demo調(diào)用時(shí)報(bào)no provider的錯(cuò)誤。

首先覺得他們挺有想法,把dubbo應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)搬上生產(chǎn)的公司不多。其次當(dāng)時(shí)寫文章時(shí)測試并沒有遇到問題,但本著幫讀者解決問題的態(tài)度,還是重新寫個(gè)demo測試下。

問題定位

隨手拿了一個(gè)平時(shí)測試用的dubbo demo工程(注意不是dubbo源碼中的demo),發(fā)現(xiàn)確實(shí)注冊不到zookeeper上,接著測試了不同的版本,發(fā)現(xiàn)都注冊不了,在2.7.5 ~ 2.7.11版本不報(bào)錯(cuò),2.7.12版本會(huì)報(bào)如下的NPE錯(cuò)誤

 
 
 
 
  1. 2021-06-16 13:17:31,086 [Dubbo-framework-scheduler-thread-1] ERROR org.apache.dubbo.config.bootstrap.DubboBootstrap (DubboBootstrap.java:1172) -  [DUBBO] refresh metadata and instance failed, dubbo version: 2.7.12, current host: 172.23.233.52 
  2. java.lang.NullPointerException 
  3.  at org.apache.dubbo.registry.client.metadata.ServiceInstanceMetadataUtils.calInstanceRevision(ServiceInstanceMetadataUtils.java:249) 
  4.  at org.apache.dubbo.registry.client.metadata.ServiceInstanceMetadataUtils.lambda$refreshMetadataAndInstance$6(ServiceInstanceMetadataUtils.java:272) 
  5.  at java.util.ArrayList.forEach(ArrayList.java:1259) 
  6.  at org.apache.dubbo.registry.client.metadata.ServiceInstanceMetadataUtils.refreshMetadataAndInstance(ServiceInstanceMetadataUtils.java:271) 
  7.  at org.apache.dubbo.config.bootstrap.DubboBootstrap.lambda$registerServiceInstance$20(DubboBootstrap.java:1170) 
  8.  at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 
  9.  at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:308) 
  10.  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$301(ScheduledThreadPoolExecutor.java:180) 
  11.  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:294) 
  12.  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 
  13.  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 
  14.  at java.lang.Thread.run(Thread.java:748) 

推測服務(wù)注冊時(shí)存在問題,跟著這個(gè)錯(cuò)誤棧debug,很快就定位到問題

直接導(dǎo)致NPE的是位于org.apache.dubbo.registry.client.AbstractServiceDiscovery#register

在<=2.7.11版本中

 
 
 
 
  1. @Override 
  2. public final void register(ServiceInstance serviceInstance) throws RuntimeException { 
  3.     this.serviceInstance = serviceInstance; 
  4.     doRegister(serviceInstance); 

而在2.7.12版本中代碼順序被調(diào)整成了

 
 
 
 
  1. @Override 
  2. public final void register(ServiceInstance serviceInstance) throws RuntimeException { 
  3.    doRegister(serviceInstance); 
  4.     this.serviceInstance = serviceInstance; 

為什么調(diào)整了代碼順序?qū)е铝藞?bào)錯(cuò)?

追蹤下來發(fā)現(xiàn)NPE的來源是this.serviceInstance為null,原先的代碼先對(duì)其賦值再執(zhí)行doRegister。調(diào)整過后的代碼先執(zhí)行doRegister再賦值,然而在執(zhí)行diRegister時(shí)拋出異常了,不幸的是這個(gè)異常被吃掉了,doRegister的實(shí)現(xiàn)如下

 
 
 
 
  1. @Override 
  2. public final void register(ServiceInstance serviceInstance) throws RuntimeException { 
  3.  
  4.     assertDestroyed(REGISTER_ACTION); 
  5.     assertInitialized(REGISTER_ACTION); 
  6.  
  7.     executeWithEvents( 
  8.             of(new ServiceInstancePreRegisteredEvent(serviceDiscovery, serviceInstance)), 
  9.             () -> serviceDiscovery.register(serviceInstance), 
  10.             of(new ServiceInstanceRegisteredEvent(serviceDiscovery, serviceInstance)) 
  11.     ); 

而這個(gè)executeWithEvents會(huì)將異常以事件的形式發(fā)出去

 
 
 
 
  1. protected final void executeWithEvents(Optional beforeEvent, 
  2.                                        ThrowableAction action, 
  3.                                        Optional afterEvent) { 
  4.     beforeEvent.ifPresent(this::dispatchEvent); 
  5.     try { 
  6.         action.execute(); 
  7.     } catch (Throwable e) { 
  8.         dispatchEvent(new ServiceDiscoveryExceptionEvent(this, serviceDiscovery, e)); 
  9.     } 
  10.     afterEvent.ifPresent(this::dispatchEvent); 

然而這個(gè)事件丟出去之后并沒有被處理,也就是說這個(gè)異常被吃掉了。這也就是為什么之前的dubbo版本沒有拋出異常,也不能注冊上服務(wù)。

這個(gè)異常是什么?

 
 
 
 
  1. va.lang.NoClassDefFoundError: org/apache/curator/x/discovery/ServiceDiscovery 

其實(shí)只是少引入了一個(gè)依賴。加入以下以下就能解決這個(gè)問題

 
 
 
 
  1.  
  2.     org.apache.dubbo 
  3.     dubbo-registry-zookeeper 
  4.     ${version} 
  5.  

為什么當(dāng)時(shí)寫文章時(shí)沒有遇到這個(gè)問題?

恰好本次調(diào)試是基于一個(gè)demo工程,《dubbo應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)初體驗(yàn)》文章是直接在dubbo源碼中修改demo,源碼中已經(jīng)把依賴都引入了

更進(jìn)一步

其實(shí)是個(gè)小問題,但對(duì)用戶來說挺困惑的,為什么沒有報(bào)錯(cuò)但也沒法注冊服務(wù)?如果不是2.7.12有個(gè)附帶的報(bào)錯(cuò),可能排查起來更加困難。

于是提了個(gè)issue和社區(qū)的朋友交流下,得出的結(jié)論是2.7.x的應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)不再維護(hù),3.x會(huì)繼續(xù)維護(hù)。

https://github.com/apache/dubbo/issues/8061

提個(gè)issue也是讓有問題的用戶能搜索到,少走彎路。

順便也提了個(gè)PR,加一行l(wèi)og,方便直觀的發(fā)現(xiàn)這個(gè)問題。

https://github.com/apache/dubbo/pull/8066

新版本(>=2.7.13)如果有朋友再遇到這個(gè)問題,會(huì)直接打印出錯(cuò)誤,就像這樣

 
 
 
 
  1. 2021-06-16 16:58:02,210 [main] ERROR org.apache.dubbo.registry.client.EventPublishingServiceDiscovery (EventPublishingServiceDiscovery.java:287) -  [DUBBO] Execute action throws and dispatch a ServiceDiscoveryExceptionEvent, dubbo version: 2.7.12, current host: 172.23.233.52 
  2. java.lang.BootstrapMethodError: java.lang.NoClassDefFoundError: org/apache/curator/x/discovery/ServiceDiscovery 
  3.  at org.apache.dubbo.registry.zookeeper.ZookeeperServiceDiscovery.doRegister(ZookeeperServiceDiscovery.java:92) 
  4.  at org.apache.dubbo.registry.client.AbstractServiceDiscovery.register(AbstractServiceDiscovery.java:33) 
  5.  at org.apache.dubbo.registry.client.EventPublishingServiceDiscovery.lambda$register$0(EventPublishingServiceDiscovery.java:159) 
  6.  at org.apache.dubbo.registry.client.EventPublishingServiceDiscovery.executeWithEvents(EventPublishingServiceDiscovery.java:285) 
  7.  at org.apache.dubbo.registry.client.EventPublishingServiceDiscovery.register(EventPublishingServiceDiscovery.java:157) 
  8.  at org.apache.dubbo.config.bootstrap.DubboBootstrap.lambda$doRegisterServiceInstance$21(DubboBootstrap.java:1192) 
  9.  at java.util.ArrayList.forEach(ArrayList.java:1259) 
  10.   ... 

既然2.7.x的應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)不再更新,下次寫一篇分析3.0版本的應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)源碼的文章吧~


當(dāng)前名稱:Dubbo 2.7應(yīng)用級(jí)服務(wù)發(fā)現(xiàn)踩坑小記
分享鏈接:http://www.5511xx.com/article/djopsdc.html