如何基於 Dubbo 進行服務治理、服務降級、失敗重試以及超時重試?

本博客轉自git項目advancejava

服務治理

1. 調用鏈路自動生成
一個大型的分佈式系統,或者說是用現在流行的微服務架構來說吧,分佈式系統由大量的服務組成。那麼這些服務之間互相是如何調用的?調用鏈路是啥?說實話,幾乎到後面沒人搞的清楚了,因爲服務實在太多了,可能幾百個甚至幾千個服務。

那就需要基於 dubbo 做的分佈式系統中,對各個服務之間的調用自動記錄下來,然後自動將各個服務之間的依賴關係和調用鏈路生成出來,做成一張圖,顯示出來,大家纔可以看到對吧。
在這裏插入圖片描述
2. 服務訪問壓力以及時長統計
需要自動統計各個接口和服務之間的調用次數以及訪問延時,而且要分成兩個級別。
• 一個級別是接口粒度,就是每個服務的每個接口每天被調用多少次,TP50/TP90/TP99,三個檔次的請求延時分別是多少;
• 第二個級別是從源頭入口開始,一個完整的請求鏈路經過幾十個服務之後,完成一次請求,每天全鏈路走多少次,全鏈路請求延時的 TP50/TP90/TP99,分別是多少。
這些東西都搞定了之後,後面纔可以來看當前系統的壓力主要在哪裏,如何來擴容和優化啊。

3. 其它
• 服務分層(避免循環依賴)
• 調用鏈路失敗監控和報警
• 服務鑑權
• 每個服務的可用性的監控(接口調用成功率?幾個9?99.99%,99.9%,99%。)

服務降級

比如說服務 A調用服務 B,結果服務 B 掛掉了,服務 A 重試幾次調用服務 B,還是不行,那麼直接降級,走一個備用的邏輯,給用戶返回響應。
舉個栗子,我們有接口 HelloServiceHelloServiceImpl 有該接口的具體實現。

public interface HelloService {
void sayHello();
}
public class HelloServiceImpl implements HelloService {
public void sayHello() {
        System.out.println("hello world......");
    }
        
}
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans.xsd        http://code.alibabatech.com/schema/dubbo        http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:application name="dubbo-provider" />
    <dubbo:registry address="zookeeper://127.0.0.1:2181" />
    <dubbo:protocol name="dubbo" port="20880" />
    <dubbo:service interface="com.zhss.service.HelloService" ref="helloServiceImpl" timeout="10000" />
    <bean id="helloServiceImpl" class="com.zhss.service.HelloServiceImpl" />
</beans>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans.xsd        http://code.alibabatech.com/schema/dubbo        http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<dubbo:application name="dubbo-consumer"  />
<dubbo:registry address="zookeeper://127.0.0.1:2181" />
<dubbo:reference id="fooService" interface="com.test.service.FooService"  timeout="10000" check="false" mock="return null">
    </dubbo:reference>
</beans>

我們調用接口失敗的時候,可以通過 mock 統一返回 null。
mock 的值也可以修改爲 true,然後再跟接口同一個路徑下實現一個 Mock 類,命名規則是 “接口名稱+Mock” 後綴。然後在 Mock 類裏實現自己的降級邏輯。

public class HelloServiceMock implements HelloService {
public void sayHello() {
        // 降級邏輯
    }
}

失敗重試和超時重試

所謂失敗重試,就是 consumer 調用 provider 要是失敗了,比如拋異常了,此時應該是可以重試的,或者調用超時了也可以重試。配置如下:
<dubbo:reference id=“xxxx” interface=“xx” check=“true” async=“false” retries=“3” timeout=“2000”/>
某個服務的接口,要耗費 5s,你這邊不能幹等着,你這邊配置了 timeout 之後,我等待 2s,還沒返回,我直接就撤了,不能幹等你。
可以結合你們公司具體的場景來說說你是怎麼設置這些參數的:
• timeout:一般設置爲 200ms,我們認爲不能超過 200ms 還沒返回。
• retries:設置 retries,一般是在讀請求的時候,比如你要查詢個數據,你可以設置個 retries,如果第一次沒讀到,報錯,重試指定的次數,嘗試再次讀取。

發佈了107 篇原創文章 · 獲贊 15 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章