成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Dubbo 2.7應用級服務發現踩坑小記

開發 架構
首先覺得他們挺有想法,把dubbo應用級服務發現搬上生產的公司不多。其次當時寫文章時測試并沒有遇到問題,但本著幫讀者解決問題的態度,還是重新寫個demo測試下。

 [[407480]]

背景

本文記錄最近一位讀者反饋的dubbo 2.7.x中應用級服務發現的問題,關于dubbo應用級服務發現的相關介紹可以參考之前的文章《dubbo應用級服務發現初體驗》,這里不再贅述。

讀者反饋他們在基于dubbo 2.7應用級服務發現開發dubbo網關,根據文章《dubbo應用級服務發現初體驗》寫了demo調用時報no provider的錯誤。

首先覺得他們挺有想法,把dubbo應用級服務發現搬上生產的公司不多。其次當時寫文章時測試并沒有遇到問題,但本著幫讀者解決問題的態度,還是重新寫個demo測試下。

問題定位

隨手拿了一個平時測試用的dubbo demo工程(注意不是dubbo源碼中的demo),發現確實注冊不到zookeeper上,接著測試了不同的版本,發現都注冊不了,在2.7.5 ~ 2.7.11版本不報錯,2.7.12版本會報如下的NPE錯誤

  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) 

推測服務注冊時存在問題,跟著這個錯誤棧debug,很快就定位到問題

直接導致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版本中代碼順序被調整成了

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

為什么調整了代碼順序導致了報錯?

追蹤下來發現NPE的來源是this.serviceInstance為null,原先的代碼先對其賦值再執行doRegister。調整過后的代碼先執行doRegister再賦值,然而在執行diRegister時拋出異常了,不幸的是這個異常被吃掉了,doRegister的實現如下

  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.     ); 

而這個executeWithEvents會將異常以事件的形式發出去

  1. protected final void executeWithEvents(Optional<? extends Event> beforeEvent, 
  2.                                        ThrowableAction action
  3.                                        Optional<? extends Event> 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); 

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

這個異常是什么?

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

其實只是少引入了一個依賴。加入以下以下就能解決這個問題

  1. <dependency> 
  2.     <groupId>org.apache.dubbo</groupId> 
  3.     <artifactId>dubbo-registry-zookeeper</artifactId> 
  4.     <version>${version}</version> 
  5. </dependency> 

 

為什么當時寫文章時沒有遇到這個問題?

恰好本次調試是基于一個demo工程,《dubbo應用級服務發現初體驗》文章是直接在dubbo源碼中修改demo,源碼中已經把依賴都引入了

更進一步

其實是個小問題,但對用戶來說挺困惑的,為什么沒有報錯但也沒法注冊服務?如果不是2.7.12有個附帶的報錯,可能排查起來更加困難。

于是提了個issue和社區的朋友交流下,得出的結論是2.7.x的應用級服務發現不再維護,3.x會繼續維護。

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

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

順便也提了個PR,加一行log,方便直觀的發現這個問題。

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

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

  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的應用級服務發現不再更新,下次寫一篇分析3.0版本的應用級服務發現源碼的文章吧~

責任編輯:武曉燕 來源: 捉蟲大師
相關推薦

2023-09-22 11:29:11

JavasubList

2024-08-06 09:08:59

2021-09-03 08:50:50

Dubbo服務引用

2023-01-18 23:20:25

編程開發

2020-09-15 08:46:26

Kubernetes探針服務端

2017-10-24 13:02:29

2025-04-09 09:31:29

2023-02-20 08:11:04

2021-10-28 19:10:02

Go語言編碼

2017-05-05 08:12:51

Spark共享變量

2021-09-03 11:15:18

場景sql配置

2024-04-10 08:39:56

BigDecimal浮點數二進制

2024-04-01 08:05:27

Go開發Java

2018-07-13 09:38:54

2021-05-27 22:46:00

Nacos Clien版本Nacos

2017-07-17 15:46:20

Oracle并行機制

2021-10-15 06:49:37

MySQL

2022-11-18 07:34:12

Docker項目目錄

2024-10-09 08:09:11

2025-05-27 01:55:00

MySQL數據庫工具鏈
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区三区视频在线观看 | 精品欧美色视频网站在线观看 | 成人av免费 | 一道本视频 | 国产免费一区二区三区 | 狠狠干美女 | 毛片免费在线 | 拍拍无遮挡人做人爱视频免费观看 | 国产精品中文字幕在线观看 | 国产免费视频 | 精品国产99 | 中文字幕日韩三级 | 在线不卡视频 | 亚洲+变态+欧美+另类+精品 | www国产精| 国产日韩欧美91 | 黄色国产 | 日韩图区| 久久久久久国产精品 | 99精品网站 | a级黄色毛片免费播放视频 国产精品视频在线观看 | 久草在线 | 不卡欧美 | 亚洲国产成人精品女人久久久 | 噜啊噜在线 | 久草免费在线视频 | 91久久夜色精品国产网站 | 成人午夜在线 | 国产精品网页 | 精品久久久久久一区二区 | 亚洲欧美日韩在线一区二区 | 暴草美女| 欧美男人天堂 | 天天草天天操 | 色橹橹欧美在线观看视频高清 | 99爱国产 | 一区二区精品视频 | 成人免费观看男女羞羞视频 | 日韩在线精品强乱中文字幕 | 免费精品视频在线观看 | 麻豆a级片 |