日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 單片機 > 架構師社區(qū)
[導讀]作者|孫玄/陳東 分布式系統(tǒng)中,大部分系統(tǒng)調用都會涉及到負載均衡,例如:客戶端發(fā)往服務端的請求首先到達反向代理,然后反向代理再通過負載均衡算法將請求轉發(fā)到業(yè)務系統(tǒng);或者后端業(yè)務系統(tǒng)各模塊間的調用前,也需要通過負載均衡算法選擇到一個目標節(jié)點。

傳授“帶權重的負載均衡實現(xiàn)算法”獨家設計思路!

作者|孫玄/陳東

分布式系統(tǒng)中,大部分系統(tǒng)調用都會涉及到負載均衡,例如:客戶端發(fā)往服務端的請求首先到達反向代理,然后反向代理再通過負載均衡算法將請求轉發(fā)到業(yè)務系統(tǒng);或者后端業(yè)務系統(tǒng)各模塊間的調用前,也需要通過負載均衡算法選擇到一個目標節(jié)點。


一般情況下,我們對負載均衡的要求就是均勻,確保調用方的請求流量能夠均勻的發(fā)送到我們冗余部署的N個服務節(jié)點上,所以負載均衡的算法一般使用隨機或輪詢都可以保證被調用結點流量的均勻。


真實情況下,往往由于部署服務的服務器性能或資源分配等原因需要我們?yōu)榉战Y點設置不同的權重,權重高的結點可以分配多一些的流量,同時降低權重低的結點的流量比例。


這時負載均衡就不能簡單的使用隨機或者輪詢了,需要添加對權重的支持。接下來我們分析幾種帶權重的負載均衡算法,并分析一下他們的優(yōu)缺點:

-     使用隨機數(shù)     -

設計思路如下:首先經(jīng)過負載均衡后選擇到一個結點,然后我們根據(jù)權重值再做一道攔截,按權重按比例放行,實現(xiàn)按降低結點流量的效果。例如我們規(guī)定權重的范圍從010之間,0拒絕,10放行。權重值越高,分配的流量就越多。


最簡單的實現(xiàn)方案,可以使用隨機值,假設設置目標結點的權重值為7,當結點被負載均衡選中后,我們生成一個010之間的隨機數(shù),小于7放行,大于7則不向目標結點發(fā)送請求,需要從新做負載均衡計算,由此實現(xiàn)了將目標結點的流量降低到原來的70%。


方案實現(xiàn)起來很簡單,但問題也很明顯,我們都知道生成隨機數(shù)的計算會造成CPU的開銷,計算權重又發(fā)生在RPC調用過程中,所以每次RPC請求都會額外的增加一次隨機數(shù)計算,累積起來對CPU額外的開銷就很大了。我們可以進一步優(yōu)化一下。

-     隨機數(shù)組     -

我們可以使用一個隨機數(shù)組代替上文描述的生成隨機數(shù)的策略,實現(xiàn)同樣效果的同時能夠減少CPU的計算量。接下來描述下隨機數(shù)組算法,同樣權重設計為0~10


我們?yōu)槊總€被調用的結點都生成一個隨機數(shù)組,數(shù)組長度為10??臻g分配好后用01填充數(shù)組,0的個數(shù)與結點的權重值一樣,同時要保證0在數(shù)組中出現(xiàn)的位置是隨機的。


我們生成一個代表權重為“4”的隨機數(shù)組(40)。


和隨機數(shù)方案類似,我們在完成負載均衡計算后,進行權重攔截。這個時候我們可以通過訪問隨機數(shù)組代替生成隨機數(shù)的計算,方案描述如下:記錄上一次訪問隨機數(shù)組的位置,取數(shù)組下一位置元素值,取到0則放行,1則拒絕,重新進行負載均衡計算。方案的思路是,輪詢訪問隨機數(shù)組,到達隨機效果。因為數(shù)組的內容是隨機的。


這兩種方案思路是一致的,都是在負載均衡計算后再加一道權重攔截。但這樣的問題是流量控制不精確,無法實現(xiàn)精確個節(jié)點按權重比例分配流量。我們可以換個思路,實現(xiàn)精確的流量控制。


-     輪詢加權重負載策略     -

設計思路如下,設計一個權重因子,初始值為所有被調用的結點中最大權重值。負載均衡使用輪詢算法,被選中結點權重值大于等于權重因子則可以調用,否則用下一結點的權重值與權重因子比較,一輪循環(huán)結束后如果沒有選中結點,則降低權重因子,繼續(xù)通過與權重因子比較進行選擇,直到選中為止。權重因子降為0后,恢復為最大權重值。


上述偽代碼中幾個變量意義如下:

  • i:當前輪詢的結點;

  • n:可選擇結點數(shù)量;

  • cw:權重因子;

  • gcd(s):權重因子每次降低的步長;

  • max(s):所有結點中最大的權重值;

  • W(si):結點Si的權重值;

  • Si:服務結點(S0~Sn-1,共n個)

權重因子的降低步長為所有結點權重值的最大公約數(shù)。


假設有4個結點,AB,CD,權重值分別為,8,6,4,2,各結點權重值得最大公約數(shù)為2,所以權重降低步長為2,通過上面的偽代碼,我們推演下負載均衡的流量分配結果。


初始條件:

  • 1、i0開始循環(huán);

  • 2、權重因子為8(偽代碼中初始化為0,減權重因子后小于0,被恢復為最大值)



第一次調用:i=0,A權重大于等于權重因子(8),可以調用A

第二次調用:i=1,B權重小于8,不可以調用,繼續(xù)循環(huán);

......

第二次調用會選擇哪個結點呢,以及后面的調用如何選擇的,歡迎大家在評留言給出自己的推演結果。


另外權重因子的降低步長為什么是最大公約數(shù)呢?歡迎大家在評論區(qū)交流。

特別推薦一個分享架構+算法的優(yōu)質內容,還沒關注的小伙伴,可以長按關注一下:

傳授“帶權重的負載均衡實現(xiàn)算法”獨家設計思路!

長按訂閱更多精彩▼

傳授“帶權重的負載均衡實現(xiàn)算法”獨家設計思路!

如有收獲,點個在看,誠摯感謝

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉