Dubbo 2.7.1 踩坑記

来源:https://www.cnblogs.com/goodAndyxublog/archive/2019/05/16/10878186.html
-Advertisement-
Play Games

Dubbo 2.7 版本增加新特性,新系統開始使用 Dubbo 2.7.1 嘗鮮新功能。使用過程中不慎踩到這個版本的 Bug。 系統架構 Spring Boot 2.14 Release + Dubbo 2.7.1 現象 Dubbo 服務者啟動成功,正常提供服務,消費者調用偶現失敗的情況。錯誤如下圖 ...


Dubbo 2.7 版本增加新特性,新系統開始使用 Dubbo 2.7.1 嘗鮮新功能。使用過程中不慎踩到這個版本的 Bug。

系統架構

Spring Boot 2.14-Release + Dubbo 2.7.1

現象

Dubbo 服務者啟動成功,正常提供服務,消費者調用偶現失敗的情況。錯誤如下圖:

調用失敗

可以看出,主要原因為 cause: message can not send, because channel is closed。 但是檢查提供者,卻發現服務進程正常。

登陸 Dubbo admin 查看提供者服務,發現這個服務存在兩個節點。

Dubbo admin

192.168.164.77 為測試伺服器的 ip,提供者位於這台機器,而另一個 10.20.80.67 卻是本地電腦的 IP,但是此時本地並未運行這個服務。

再次查看服務報錯的原因,可以看到提供者調用l本地提供 RPC 的服務。由於本地服務已停止,導致調用失敗。

這個問題在之前版本從未碰到,剛開始隱約記得 Dubbo 服務提供者註冊使用 ZooKeeper 臨時節點,服務斷開,會刪除該節點。

問題原因

在 Dubbo 主頁搜索相關 issue,看到同樣的問題 Dubbo-2.7.1 providers 重覆註冊.

查看相關回覆,可以看到問題主要由於 dynamic 預設值變成 false ,而 2.7.1 之前版本預設不賦值,初始值為 null。

問題原因

後續 PR 中已修複該問題 Fix issue 3785,修複代碼將 dynamic 預設設置成 true。但是截止 20190515 該版本暫未發佈。

源碼分析

知道問題原因,這裡我們從源碼分析一下,為什麼 dynamic 設置成 false 會導致該問題。

註:下麵分析的是 Dubbo 2.7.1 的源碼
下麵我們使用 Dubbo xml 配置相關。

在 xml 配置中,可以在以下兩個地方設置 dynamic 屬性。

xml 配置

服務啟動時將會使用 DubboNamespaceHandler 解析,註入 Spring 容器。

DubboNamespaceHandler 解析過程

其中會將 provider 標簽解析成 ProviderConfig 對象,service 標簽解析成 ServiceBean 對象。

繼承關係

查看繼承關係,可以看到以上兩個類都繼承 AbstractServiceConfig , dynamic 位於這個父對象中。

dynamic 預設值

可以看到該欄位預設值為 false

接著查看 Dubbo 服務導出過程,位於 ServiceBean#export,略過其他代碼,我們直接跳到關鍵 ServiceConfig#doExportUrlsFor1Protocol

doExportUrlsFor1Protocol

可以看到這裡調用了多次 appendParameters 方法。 這個方法將利用反射,獲取對象的中所有欄位信息,然後添加到 map 中。其中欄位名字為鍵值,欄位實際值為內容。此時 map 鍵值內容為:

map 內容

可以看到 map 中還有一個 default.dynamic,大家翻看代碼自己思考一下,為什麼會出現這個?

接著我們跳到後面:

url

在這裡會將上面得到 map 組裝到 URL 對象中,然後再註冊到註冊中心。。

由於註冊中心使用的是 ZooKeeper,所以這裡將會使用 ZookeeperRegistry 實現類。

doRegister

首先查看 url##getParameter 方法,這裡 Constants.DYNAMIC_KEY 值為 dynamic。

url##getParameter

該方法會先從 parameters 中根據鍵值取值。若不存在,會再根據 default 作為首碼拼接再次取值。若還不存在則使用傳入的預設值。

查看此時的 parameters 對象。

parameters

url.getParameter(Constants.DYNAMIC_KEY, true) 返回為 false。

然後分析 zkClient#create 方法,

zkClient#create

由於 ephemeral 為 false,所以這個服務註冊到 ZooKeeper 的節點為持久節點。

臨時節點,客戶端斷開,會話超時後,ZooKeeper 將會自動刪除這個節點。zookeeper-faq
面試題:服務提供者能實現失效踢出是什麼原理(高頻題)

服務宕機的時候,該節點由於是持久節點會永遠存在,而且當服務再次重啟的時候會將重新註冊一個新節點。這樣就導致 ZooKeeper 中存在額外失效的節點,且該節點還無法自然消除(除非手動調用 ZooKeeper 刪除節點方法)。

總結

由於 Dubbo 2.7.2 暫未發佈,所以建議若想使用 Dubbo 2.7 新功能的同學,使用 2.7.0 版本。若現在正在使用 2.7.2 版本,也不要慌張。只要服務不是異常宕機或者使用 kill -9 強制殺死進程,以上的現象將不會碰到。正常服務關閉的時候,Dubbo 服務會主動去 ZooKeeper 註銷該服務,並刪除這個節點。

還未使用該版本的同學們,建議使用 2.7.0 或者等 2.7.2 發佈以後,再使用。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 力扣題目解答自我總結(反轉類題目) 一.反轉字元串 1.題目描述 編寫一個函數,其作用是將輸入的字元串反轉過來。輸入字元串以字元數組 的形式給出。 不要給另外的數組分配額外的空間,你必須 原地修改輸入數組 、使用 O(1) 的額外空間解決這一問題。 你可以假設數組中的所有字元都是 "ASCII" 碼 ...
  • while語句的一般形式: 同樣需要註意冒號和縮進。另外,在 Python 中沒有 do..while 迴圈。 以下實例使用了 while 來計算 1 到 100 的總和: 執行結果如下: 無限迴圈: 我們可以通過設置條件表達式永遠不為 false 來實現無限迴圈,實例如下: 輸出結果如下: whi ...
  • Python字元串的方法 字元串大小寫相關 upper() 轉換字元串中的所有小寫字元為大寫。 swapcase() 翻轉字元串中的大小寫。 lower() 轉換字元串中所有大寫字元為小寫。 capitalize() 把字元串的第一個字元改為大寫。 casefold() 把整個字元串的所有字元改為小 ...
  • 如果你正在使用Spring Cloud體系,在實際使用過程中正遇到以下問題,可以閱讀本文章的內容作為後續你解決這些問題的參考,文章內容不保證無錯,請務必仔細思考之後再進行實踐。 問題: 1,本地連上開發或測試環境的集群連調,正常測試請求可能會請求到本地,被自己的debug阻塞。 2,測試環境維護時, ...
  • day23 02 組合(繼續人狗大戰游戲) 面向對象的三大特性:繼承 多態 封裝 先講解一下組合 組合:一個對象的屬性值是另一個類的對象:對象.屬性.屬性(一般有兩個點) 繼續擴展day22 01裡面的人狗大戰的小游戲來說明組合的存在,相對於之前的游戲,這次多加了一個武器裝備類,而且武器還有它的大招 ...
  • 與眾多編程語言一樣,Python變數的命名有一定的規範: 變數名只能包含字母、數字、下劃線且不能以數字開頭。例如,num_1 為正確命名,而 1_num 則錯誤。 變數名不允許含空格,但是可以用下劃線來分割單詞。num_list 是可行的,num list 則會引發錯誤。 不要將Python中的關鍵 ...
  • 7、有效的括弧 給定一個只包括 ,`')' '{' '}' '[' ']'` 的字元串,判斷字元串是否有效。 有效字元串需滿足: 1. 左括弧必須用相同類型的右括弧閉合。 2. 左括弧必須以正確的順序閉合。 註意空字元串可被認為是有效字元串。 示例 1: 解答: 8、移除元素 給定一個數組 nums ...
  • python一些內置函數 enumerate (列舉、枚舉) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...