0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

華為云服務(wù)治理—隔離倉的作用

禿頭也愛科技 ? 來源:禿頭也愛科技 ? 作者:禿頭也愛科技 ? 2023-01-18 19:41 ? 次閱讀

服務(wù)治理通常是指通過限流、熔斷等手段,保障微服務(wù)的可靠運(yùn)行,即運(yùn)行時(shí)治理。更加寬泛的服務(wù)治理還包括微服務(wù)持續(xù)集成(開源軟件管理、自動(dòng)化測(cè)試等),微服務(wù)部署最佳實(shí)踐(滾動(dòng)升級(jí)、灰度發(fā)布等),微服務(wù)可觀測(cè)性能力(日志、監(jiān)控、告警等)構(gòu)建等。

??微服務(wù)治理專題主要探討運(yùn)行時(shí)治理。隔離倉是適用于大部分故障模式,簡單有效的治理策略,本章介紹隔離倉的原理和作用。

隔離倉的定義和作用

??業(yè)務(wù)請(qǐng)求的處理都會(huì)占用系統(tǒng)資源,包括CPU、內(nèi)存、線程池、連接池等。隔離倉是一種限制業(yè)務(wù)請(qǐng)求對(duì)系統(tǒng)資源占用的服務(wù)治理策略,防止單個(gè)業(yè)務(wù)請(qǐng)求或者單個(gè)微服務(wù)實(shí)例過多的占用系統(tǒng)資源,對(duì)其他業(yè)務(wù)請(qǐng)求以及系統(tǒng)總體的性能產(chǎn)生嚴(yán)重影響。

??線程池是治理策略應(yīng)用最廣泛的系統(tǒng)資源,通常所有請(qǐng)求都在一個(gè)共享的線程池處理,常見的隔離倉實(shí)現(xiàn),都是限制請(qǐng)求對(duì)線程池的過多占用。本文以 Spring Cloud Huawei 為例,演示其隔離倉在兩種故障場(chǎng)景下的作用。

  • 場(chǎng)景一

??微服務(wù)A調(diào)用微服務(wù)B,A和B分別有M個(gè)實(shí)例,模擬N個(gè)并發(fā)客戶端連續(xù)不斷的請(qǐng)求A。然后給B擴(kuò)容1個(gè)實(shí)例。觀察應(yīng)用治理策略和不應(yīng)用策略的情況下,時(shí)延和TPS的變化情況。

  • 場(chǎng)景二

??微服務(wù)A調(diào)用微服務(wù)B,A和B分別有M個(gè)實(shí)例,B有兩個(gè)接口 X 和 Y, 其中X處理100ms,Y處理500 ms,模擬N 個(gè)并發(fā)客戶端通過A連續(xù)請(qǐng)求X接口,N 個(gè)并發(fā)客戶端通過A連續(xù)請(qǐng)求Y接口。觀察應(yīng)用治理策略和不應(yīng)用策略的情況下,時(shí)延和TPS的變化情況。

Spring Cloud Huawei客戶端隔離倉的工作原理和效果

??Spring Cloud Huawei 客戶端隔離倉 的主要作用是限制一個(gè)實(shí)例、或者一個(gè)實(shí)例的某個(gè)接口最大并發(fā)數(shù),當(dāng)一個(gè)實(shí)例的最大并發(fā)處理大于設(shè)置的閾值maxConcurrentCalls的時(shí)候,后續(xù)請(qǐng)求會(huì)在當(dāng)前線程等待maxWaitDuration時(shí)間,如果這段時(shí)間有請(qǐng)求處理完畢,那么后續(xù)請(qǐng)求會(huì)繼續(xù)處理,否則就會(huì)被丟棄,返回408錯(cuò)誤。

??Spring Cloud Huawei 服務(wù)端隔離倉 的主要作用是限制一個(gè)接口的最大并發(fā)數(shù),當(dāng)一個(gè)接口的最大并發(fā)處理大于設(shè)置的閾值maxConcurrentCalls的時(shí)候,后續(xù)請(qǐng)求會(huì)在當(dāng)前線程等待maxWaitDuration時(shí)間,如果這段時(shí)間有請(qǐng)求處理完畢,那么后續(xù)請(qǐng)求會(huì)繼續(xù)處理,否則就會(huì)被丟棄,返回408錯(cuò)誤。

  • 場(chǎng)景一

??微服務(wù)A的隔離倉配置:

servicecomb:

matchGroup:

allOperation: |

  matches:

    - apiPath:

        prefix: "/"
instanceBulkhead:

## 隔離倉限制正在處理的請(qǐng)求數(shù)為20個(gè),新來的請(qǐng)求等待1000毫秒沒有獲取到

## 許可,將被拒絕。

allOperation: |

  maxConcurrentCalls: 20

  maxWaitDuration: 1000

為了匹配測(cè)試用例,設(shè)置微服務(wù)A的線程池大小為20

server:

tomcat:

threads:

  max: 20

  minSpare: 20

??微服務(wù)A調(diào)用微服務(wù)B,A和B分別有1個(gè)實(shí)例,模擬40個(gè)并發(fā)客戶端連續(xù)不斷的請(qǐng)求A。然后給B擴(kuò)容1個(gè)實(shí)例。觀察應(yīng)用治理策略和不應(yīng)用策略的情況下,時(shí)延和TPS的變化情況。

測(cè)試結(jié)果:

不使用隔離倉:

Total time:121852

Success count:200000

Timeout count:0

Error count:0

Average Latency:24

|(10,7942)||(20,90667)||(50,93017)||(100,7041)||(200,1151)||(500,173)||(1000,9)|

使用隔離倉:

Total time:112440

Success count:200000

Timeout count:0

Error count:0

Average Latency:22

|(10,8683)||(20,100275)||(50,86137)||(100,4106)||(200,679)||(500,120)||(1000,0)|

??從上述結(jié)果可以看出使用隔離倉的情況下,時(shí)延大于200ms的請(qǐng)求明顯減少。 這個(gè)結(jié)果說明隔離倉的使用并沒有降低系統(tǒng)的處理性能,甚至可能帶來一些性能的改善,減少時(shí)延偏差較大的請(qǐng)求數(shù)量。上述測(cè)試場(chǎng)景,并沒有演示新啟動(dòng)實(shí)例導(dǎo)致故障的場(chǎng)景。如果需要模擬這種場(chǎng)景,可以考慮微服務(wù)A部署10個(gè)實(shí)例,并且采用500個(gè)并發(fā)客戶端訪問。

  • 場(chǎng)景二

微服務(wù)A的隔離倉配置:

servicecomb:

matchGroup:

allOperation: |

  matches:

    - apiPath:

        # 對(duì)耗時(shí)的接口配置隔離倉

        prefix: "/benchmark/delay/z100"
instanceBulkhead:

## 隔離倉限制正在處理的請(qǐng)求數(shù)為20個(gè),新來的請(qǐng)求等待1000毫秒沒有獲取到

## 許可,將被拒絕。

allOperation: |

maxConcurrentCalls: 20

maxWaitDuration: 1000
# 為了匹配測(cè)試用例,設(shè)置微服務(wù)A的線程池大小為40
server:

tomcat:

threads:

  max: 40

  minSpare: 40

??微服務(wù)A調(diào)用微服務(wù)B,A和B分別有1個(gè)實(shí)例,B有兩個(gè)接口 X 和 Y, 其中X處理1ms,Y處理100 ms,模擬20 個(gè)并發(fā)客戶端通過A連續(xù)請(qǐng)求X接口,20 個(gè)并發(fā)客戶端通過A連續(xù)請(qǐng)求Y接口。觀察應(yīng)用治理策略和不應(yīng)用策略的情況下,時(shí)延和TPS的變化情況。

測(cè)試結(jié)果:

不使用隔離倉:

Total time:69029

Success count:40000

Timeout count:0

Error count:0

Average Latency:68

|(10,2175)||(20,12078)||(50,5727)||(100,17)||(200,20003)||(500,0)||(1000,0)||(10000,0)|

使用隔離倉:

Total time:107354

Success count:40000

Timeout count:0

Error count:0

Average Latency:106

|(10,2217)||(20,14264)||(50,3506)||(100,7)||(200,15738)||(500,4268)||(1000,0)||(10000,0)|

??從上述結(jié)果可以看出使用隔離倉的情況下,時(shí)延小于20ms的請(qǐng)求有所增加,但是時(shí)延超過500ms的請(qǐng)求增加更加明顯。這是因?yàn)闇y(cè)試場(chǎng)景屬于IO密集型場(chǎng)景,使用隔離倉,降低了Y接口的并發(fā)度,大量請(qǐng)求排隊(duì),導(dǎo)致整體的時(shí)延大幅增長。下面把客戶端隔離倉去掉,改為服務(wù)端隔離倉,再看看效果。

微服務(wù)B的隔離倉配置:

servicecomb:

matchGroup:

allOperation: |

matches:
- apiPath:
# 對(duì)耗時(shí)的接口配置隔離倉

prefix: "/benchmark/delay/z100"

bulkhead:

## 隔離倉限制正在處理的請(qǐng)求數(shù)為20個(gè),新來的請(qǐng)求等待1000毫秒沒有獲取到

## 許可,將被拒絕。

allOperation: |

maxConcurrentCalls: 10

maxWaitDuration: 1000
# 為了匹配測(cè)試用例,設(shè)置微服務(wù)B的線程池大小為20

server:

tomcat:

threads:

max: 20

minSpare: 20

??微服務(wù)A調(diào)用微服務(wù)B,A和B分別有1個(gè)實(shí)例,B有兩個(gè)接口 X 和 Y, 其中X處理1ms,Y處理100 ms,模擬20 個(gè)并發(fā)客戶端通過A連續(xù)請(qǐng)求X接口,20 個(gè)并發(fā)客戶端通過A連續(xù)請(qǐng)求Y接口。觀察應(yīng)用治理策略和不應(yīng)用策略的情況下,時(shí)延和TPS的變化情況。

測(cè)試結(jié)果:

不使用隔離倉:

Total time:110685

Success count:40000

Timeout count:0

Error count:0

Average Latency:109

|(10,160)||(20,1207)||(50,4378)||(100,14091)||(200,19906)||(500,258)||(1000,0)||(10000,0)|

使用隔離倉:

Total time:214565

Success count:40000

Timeout count:0

Error count:0

Average Latency:213

|(10,46)||(20,734)||(50,279)||(100,3941)||(200,14972)||(500,19995)||(1000,33)||(10000,0)|

??從上述結(jié)果可以看出使用隔離倉的情況下,平均時(shí)延和性能同樣會(huì)下降。我們適當(dāng)調(diào)整下隔離倉的限制,快速丟棄一些請(qǐng)求:

servicecomb:

matchGroup:

allOperation: |

matches:

- apiPath:
  
  # 對(duì)耗時(shí)的接口配置隔離倉

prefix: "/benchmark/delay/z100"


bulkhead:

## 隔離倉限制正在處理的請(qǐng)求數(shù)為20個(gè),新來的請(qǐng)求等待1000毫秒沒有獲取到

## 許可,將被拒絕。

allOperation: |

maxConcurrentCalls: 10

maxWaitDuration: 10
# 為了匹配測(cè)試用例,設(shè)置微服務(wù)B的線程池大小為20

server:

tomcat:


threads:

max: 20

minSpare: 20

使用隔離倉的測(cè)試結(jié)果:

Total time:68189

Success count:22733

Timeout count:1

Error count:17266

Average Latency:115

|(10,53)||(20,2096)||(50,19470)||(100,13025)||(200,3885)||(500,1361)||(1000,109)||(10000,1)|

??上述結(jié)果可以看出,快速丟棄請(qǐng)求的情況下,時(shí)延小于50ms的請(qǐng)求大于20000個(gè)。隔離倉保證了處理很快的接口能夠得到快速成功執(zhí)行,前提條件是處理很慢的接口不占用資源,快速失敗。

隔離倉總結(jié)

??隔離倉的使用,在計(jì)算密集型場(chǎng)景下,對(duì)系統(tǒng)的性能影響很小,甚至可以起到一定的性能改善作用。在IO密集型場(chǎng)景下,由于隔離倉降低了請(qǐng)求的并發(fā)執(zhí)行線程,會(huì)導(dǎo)致吞吐量降低和時(shí)延增加。

??也可以看出,在IO等待比較長的情況下,系統(tǒng)的吞吐量和系統(tǒng)的可靠性是兩個(gè)沒法同時(shí)滿足的目標(biāo),如果要保證成功率不降低,并且吞吐量增加,那么勢(shì)必增加業(yè)務(wù)線程等系統(tǒng)資源占用,從而對(duì)系統(tǒng)整體的可靠性產(chǎn)生影響。對(duì)于耗時(shí)的請(qǐng)求,只能通過快速丟棄超過資源使用限制的部分,才能夠保證系統(tǒng)吞吐量不下降,并且避免產(chǎn)生系統(tǒng)性的全局功能影響。因此,系統(tǒng)應(yīng)該合理的設(shè)計(jì)部分耗時(shí)請(qǐng)求的最大并發(fā),在超過這些指標(biāo)的時(shí)候,快速丟棄多余的請(qǐng)求。過度追求耗時(shí)請(qǐng)求的吞吐量而擴(kuò)大線程池、連接池等,是很多應(yīng)用系統(tǒng)最常見的設(shè)計(jì)誤區(qū)。

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • IO
    IO
    +關(guān)注

    關(guān)注

    0

    文章

    454

    瀏覽量

    39235
  • 華為云
    +關(guān)注

    關(guān)注

    3

    文章

    2673

    瀏覽量

    17503
收藏 人收藏

    評(píng)論

    相關(guān)推薦

      華為深度學(xué)習(xí)服務(wù),讓企業(yè)智能從此不求人

      近日,華為發(fā)布了深度學(xué)習(xí)服務(wù),要讓企業(yè)智能從此不求人。那么企業(yè)的深度學(xué)習(xí)服務(wù)有哪些能力,為什么能夠做到讓企業(yè)智能從此不求人呢?!  ?/div>
    發(fā)表于 08-02 20:44

     華為ServiceStage完美支持多個(gè)主流源碼托管倉庫

    隨著“微服務(wù)架構(gòu)”的快速發(fā)展,傳統(tǒng)應(yīng)用向微服務(wù)轉(zhuǎn)移已成為行業(yè)趨勢(shì),越來越多的公司及開發(fā)者從免費(fèi)服務(wù)器的發(fā)展中受益。   華為
    發(fā)表于 08-03 13:58

    求助!關(guān)于華為平臺(tái)對(duì)numa的要求

    最近有客戶想在AMD雙路服務(wù)器上裝華為平臺(tái),但是總無法安裝,問了華為工程師,他說華為平臺(tái)的
    發(fā)表于 07-11 10:29

    華為FPGA加速服務(wù)器如何加速讓硬件應(yīng)用高效上?

    華為FPGA加速服務(wù)器讓“硬用”上成為新增長點(diǎn)隨著通信和互聯(lián)網(wǎng)產(chǎn)業(yè)的快速發(fā)展,F(xiàn)PGA作為高性能計(jì)算加速器在大數(shù)據(jù)、深度學(xué)習(xí)、圖像視頻處理、基因計(jì)算、金融分析和加解密等眾多領(lǐng)域得到
    發(fā)表于 10-22 07:12

    華為彈性服務(wù)器上遠(yuǎn)程編譯RK3568的相關(guān)資料介紹

    1、在華為彈性服務(wù)器上遠(yuǎn)程編譯rk3568配置華為彈性服務(wù)器首先注冊(cè)并登陸
    發(fā)表于 09-08 17:06

    華為服務(wù)是什么_怎么使用

    華為成立于2011年,隸屬于華為公司,在北京、深圳、南京、美國等多地設(shè)立有研發(fā)和運(yùn)營機(jī)構(gòu),貫徹華為公司“、管、端”的戰(zhàn)略方針,匯集海內(nèi)外
    發(fā)表于 12-25 15:12 ?1.9w次閱讀

    華為國內(nèi)首發(fā)Istio服務(wù)網(wǎng)格

    華為國內(nèi)首家推出了Istio服務(wù)網(wǎng)格產(chǎn)品,該產(chǎn)品與CCE容器引擎深度整合,提供非侵入、智能流量治理的應(yīng)用全生命周期管理方案,增強(qiáng)了華為
    的頭像 發(fā)表于 09-08 09:36 ?3786次閱讀

    華為ECS,最專業(yè)的服務(wù)專家

    隨著互聯(lián)網(wǎng)大數(shù)據(jù)技術(shù)的飛速發(fā)展,越來越多的企業(yè)也紛紛開始搭建自己的服務(wù)架構(gòu),并迫切地希望將自身的傳統(tǒng)業(yè)務(wù)上,以此加快企業(yè)數(shù)字化轉(zhuǎn)型的步伐。華為
    的頭像 發(fā)表于 12-31 19:21 ?1354次閱讀
    <b class='flag-5'>華為</b><b class='flag-5'>云</b>ECS,最專業(yè)的<b class='flag-5'>云</b><b class='flag-5'>服務(wù)</b>專家

    華為服務(wù)治理?| 微服務(wù)常見故障模式

    ),微服務(wù)可觀測(cè)性能力(日志、監(jiān)控、告警等)構(gòu)建等。 華為服務(wù)治理專題主要探討運(yùn)行時(shí)治理。我
    的頭像 發(fā)表于 01-18 17:44 ?787次閱讀

    華為服務(wù)治理 | 服務(wù)治理的一般性原則

    華為 服務(wù)治理 | ** 服務(wù)治理的一般性原則** 服務(wù)
    的頭像 發(fā)表于 01-18 18:19 ?552次閱讀

    智領(lǐng)睿變,共建綠色數(shù)智金融 -- 華為數(shù)3.0發(fā)布

    華為GaussDB(DWS)作為新一代全場(chǎng)景云數(shù)據(jù)倉庫,提供批量數(shù)、實(shí)時(shí)數(shù)以及IoT數(shù)三種服務(wù)
    的頭像 發(fā)表于 06-08 21:58 ?548次閱讀
    智領(lǐng)睿變,共建綠色數(shù)智金融 -- <b class='flag-5'>華為</b><b class='flag-5'>云</b>數(shù)<b class='flag-5'>倉</b>3.0發(fā)布

    華為發(fā)布 CodeArts?Governance 開源治理服務(wù),開源使用更安心

    2023 年 9 月 14 日,華為正式發(fā)布 CodeArts?Governance 開源治理服務(wù)。這是一款針對(duì)軟件研發(fā)提供的一站式開源軟件治理
    的頭像 發(fā)表于 10-12 15:41 ?461次閱讀
    <b class='flag-5'>華為</b><b class='flag-5'>云</b>發(fā)布 CodeArts?Governance 開源<b class='flag-5'>治理</b><b class='flag-5'>服務(wù)</b>,開源使用更安心

    華為 CodeArts?開源治理服務(wù),解鎖軟件安全新標(biāo)準(zhǔn)

    在數(shù)字化時(shí)代,軟件的安全性日益受到關(guān)注,而開源軟件的快速發(fā)展也帶來了新的挑戰(zhàn)。再次背景下,華為開源治理服務(wù)華為
    的頭像 發(fā)表于 12-10 21:00 ?1008次閱讀
    <b class='flag-5'>華為</b><b class='flag-5'>云</b> CodeArts?開源<b class='flag-5'>治理</b><b class='flag-5'>服務(wù)</b>,解鎖軟件安全新標(biāo)準(zhǔn)

    中軟國際數(shù)據(jù)治理專業(yè)服務(wù)解決方案獲得華為聯(lián)合基線解決方案認(rèn)證

    近日,中軟國際聯(lián)合華為生態(tài)及技術(shù)團(tuán)隊(duì)共同設(shè)計(jì)的數(shù)據(jù)治理專業(yè)服務(wù)解決方案成功通過華為基線解決方
    的頭像 發(fā)表于 12-20 20:25 ?903次閱讀
    中軟國際數(shù)據(jù)<b class='flag-5'>治理</b>專業(yè)<b class='flag-5'>服務(wù)</b>解決方案獲得<b class='flag-5'>華為</b><b class='flag-5'>云</b>聯(lián)合基線解決方案認(rèn)證

    軟通動(dòng)力成為華為聯(lián)合基線解決方案TOP1服務(wù)

    近日,軟通動(dòng)力與華為長期以來的深入合作、深度協(xié)作再結(jié)碩果,雙方共同設(shè)計(jì)的企業(yè)上服務(wù)解決方案、數(shù)據(jù)中臺(tái)及數(shù)據(jù)治理
    的頭像 發(fā)表于 01-09 10:59 ?848次閱讀
    軟通動(dòng)力成為<b class='flag-5'>華為</b><b class='flag-5'>云</b>聯(lián)合基線解決方案TOP1<b class='flag-5'>服務(wù)</b>商