色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

應對高并發的手段之一自適應限流

電子工程師 ? 來源:博客 ? 作者:fredalxin ? 2021-05-27 15:52 ? 次閱讀

作為應對高并發的手段之一,限流并不是一個新鮮的話題了。從Guava的Ratelimiter到Hystrix,以及Sentinel都可作為限流的工具。

Part1自適應限流

一般的限流常常需要指定一個固定值(qps)作為限流開關的閾值,這個值一是靠經驗判斷,二是靠通過大量的測試數據得出。但這個閾值,在流量激增、系統自動伸縮或者某某commit了一段有毒代碼后就有可能變得不那么合適了。并且一般業務方也不太能夠正確評估自己的容量,去設置一個合適的限流閾值。

而此時自適應限流就是解決這樣的問題的,限流閾值不需要手動指定,也不需要去預估系統的容量,并且閾值能夠隨著系統相關指標變化而變化。

自適應限流算法借鑒了TCP擁塞算法,根據各種指標預估限流的閾值,并且不斷調整。大致獲得的效果如下:

55d0f872-be45-11eb-9e57-12bb97331649.jpg

從圖上可以看到,首先以一個降低的初始并發值發送請求,同時通過增大限流窗口來探測系統更高的并發性。而一旦延遲增加到一定程度了,又會退回到較小的限流窗口。循環往復持續探測并發極限,從而產生類似鋸齒狀的時間關系函數。

Part2TCP Vegas

vegas是一種主動調整cwnd的擁塞控制算法,主要是設置兩個閾值alpha 和 beta,然后通過計算目標速率和實際速率的差diff,再比較差diff與alpha和beta的關系,對cwnd進行調節。偽代碼如下:

diff = cwnd*(1-baseRTT/RTT)

if (diff 《 alpha)

set: cwnd = cwnd + 1

else if (diff 》= beta)

set: cwnd = cwnd - 1else

set: cwnd = cwnd

其中baseRTT指的是測量的最小往返時間,RTT指的是當前測量的往返時間,cwnd指的是當前的TCP窗口大小。通常在tcp中alpha會被設置成2-3,beta會被設置成4-6。這樣子,cwnd就保持在了一個平衡的狀態。

Part3netflix-concuurency-limits

concuurency-limits是netflix推出的自適應限流組件,借鑒了TCP相關擁塞控制算法,主要是根據請求延時,及其直接影響到的排隊長度來進行限流窗口的動態調整。

alpha , beta & threshold

vegas算法實現在了VegasLimit類中。先看一下初始化相關代碼:

private int initialLimit = 20;

private int maxConcurrency = 1000;

private MetricRegistry registry = EmptyMetricRegistry.INSTANCE;

private double smoothing = 1.0;

private Function《Integer, Integer》 alphaFunc = (limit) -》 3 * LOG10.apply(limit.intValue());

private Function《Integer, Integer》 betaFunc = (limit) -》 6 * LOG10.apply(limit.intValue());

private Function《Integer, Integer》 thresholdFunc = (limit) -》 LOG10.apply(limit.intValue());

private Function《Double, Double》 increaseFunc = (limit) -》 limit + LOG10.apply(limit.intValue());

private Function《Double, Double》 decreaseFunc = (limit) -》 limit - LOG10.apply(limit.intValue());

這里首先定義了一個初始化值initialLimit為20,以及極大值maxConcurrency1000。其次是三個閾值函數alphaFunc,betaFunc以及thresholdFunc。最后是兩個增減函數increaseFunc和decreaseFunc。函數都是基于當前的并發值limit做運算的。

alphaFunc可類比vegas算法中的alpha,此處的實現是3*log limit。limit值從初始20增加到極大1000時候,相應的alpha從3.9增加到了9。

betaFunc則可類比為vegas算法中的beta,此處的實現是6*log limit。limit值從初始20增加到極大1000時候,相應的alpha從7.8增加到了18。

thresholdFunc算是新增的一個函數,表示一個較為初始的閾值,小于這個值的時候limit會采取激進一些的增量算法。這里的實現是1倍的log limit。mit值從初始20增加到極大1000時候,相應的alpha從1.3增加到了3。

這三個函數值可以認為確定了動態調整函數的四個區間范圍。當變量queueSize = limit × (1 ? RTTnoLoad/RTTactual)落到這四個區間的時候應用不同的調整函數。

變量queueSize

其中變量為queueSize,計算方法即為limit × (1 ? RTTnoLoad/RTTactual),為什么這么計算其實稍加領悟一下即可。

我們把系統處理請求的過程想象為一個水管,到來的請求是往這個水管灌水,當系統處理順暢的時候,請求不需要排隊,直接從水管中穿過,這個請求的RT是最短的,即RTTnoLoad;反之,當請求堆積的時候,那么處理請求的時間則會變為:排隊時間+最短處理時間,即RTTactual = inQueueTime + RTTnoLoad。而顯然排隊的隊列長度為總排隊時間/每個請求的處理時間及queueSize = (limit * inQueueTime) / (inQueueTime + RTTnoLoad) = limit × (1 ? RTTnoLoad/RTTactual)。再舉個栗子,因為假設當前延時即為最佳延時,那么自然是不用排隊的,即queueSize=0。而假設當前延時為最佳延時的一倍的時候,可以認為處理能力折半,100個流量進來會有一半即50個請求在排隊,及queueSize= 100 * (1 ? 1/2)=50。

動態調整函數

調整函數中最重要的即增函數與減函數。從初始化的代碼中得知,增函數increaseFunc實現為limit+log limit,減函數decreaseFunc實現為limit-log limit,相對來說增減都是比較保守的。

看一下應用動態調整函數的相關代碼:

private int updateEstimatedLimit(long rtt, int inflight, boolean didDrop) {

final int queueSize = (int) Math.ceil(estimatedLimit * (1 - (double)rtt_noload / rtt));

double newLimit;

// Treat any drop (i.e timeout) as needing to reduce the limit

// 發現錯誤直接應用減函數decreaseFunc

if (didDrop) {

newLimit = decreaseFunc.apply(estimatedLimit);

// Prevent upward drift if not close to the limit

} else if (inflight * 2 《 estimatedLimit) {

return (int)estimatedLimit;

} else {

int alpha = alphaFunc.apply((int)estimatedLimit);

int beta = betaFunc.apply((int)estimatedLimit);

int threshold = this.thresholdFunc.apply((int)estimatedLimit);

// Aggressive increase when no queuing

if (queueSize 《= threshold) {

newLimit = estimatedLimit + beta;

// Increase the limit if queue is still manageable

} else if (queueSize 《 alpha) {

newLimit = increaseFunc.apply(estimatedLimit);

// Detecting latency so decrease

} else if (queueSize 》 beta) {

newLimit = decreaseFunc.apply(estimatedLimit);

// We‘re within he sweet spot so nothing to do

} else {

return (int)estimatedLimit;

}

}

newLimit = Math.max(1, Math.min(maxLimit, newLimit));

newLimit = (1 - smoothing) * estimatedLimit + smoothing * newLimit;

if ((int)newLimit != (int)estimatedLimit && LOG.isDebugEnabled()) {

LOG.debug(“New limit={} minRtt={} ms winRtt={} ms queueSize={}”,

(int)newLimit,

TimeUnit.NANOSECONDS.toMicros(rtt_noload) / 1000.0,

TimeUnit.NANOSECONDS.toMicros(rtt) / 1000.0,

queueSize);

}

estimatedLimit = newLimit;

return (int)estimatedLimit;

}

動態調整函數規則如下:

當變量queueSize 《 threshold時,選取較激進的增量函數,newLimit = limit+beta

當變量queueSize 《 alpha時,需要增大限流窗口,選擇增函數increaseFunc,即newLimit = limit + log limit

當變量queueSize處于alpha,beta之間時候,limit不變

當變量queueSize大于beta時候,需要收攏限流窗口,選擇減函數decreaseFunc,即newLimit = limit - log limit

平滑遞減 smoothingDecrease

注意到可以設置變量smoothing,這里初始值為1,表示平滑遞減不起作用。如果有需要的話可以按需設置,比如設置smoothing為0.5時候,那么效果就是采用減函數decreaseFunc時候效果減半,實現方式為newLimitAfterSmoothing = 0.5 newLimit + 0.5 limit

作者丨fredalxin

來源丨fredal.xin/netflix-concuurency-limits

原文標題:見過自適應的限流神奇嗎?

文章出處:【微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 代碼
    +關注

    關注

    30

    文章

    4791

    瀏覽量

    68685
  • 限流
    +關注

    關注

    0

    文章

    34

    瀏覽量

    22538

原文標題:見過自適應的限流神奇嗎?

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    空間光調制器自適應激光光束整形

    調制器(SLM)在控制和調制激光方面具有無限的可能: ?自適應光學 ?超分辨顯微鏡 ?光鑷 ?激光材料處理 ?量子光學 SLM光束整形: 將個高斯光束轉換成高帽輪廓 VirtualLab
    發表于 12-12 10:33

    AMD自適應和嵌入式產品技術日日程上線

    AMD 自適應和嵌入式產品技術日 –北京站活動日程現已上線!
    的頭像 發表于 10-25 10:02 ?245次閱讀

    步進電機如何自適應控制?步進電機如何細分驅動控制?

    步進電機是種將電脈沖信號轉換為角位移或線位移的電機,廣泛應用于各種自動化控制系統中。為了提高步進電機的性能,自適應控制和細分驅動控制是兩種重要的技術手段、步進電機的
    的頭像 發表于 10-23 10:04 ?562次閱讀

    TDP1204和TMDS1204如何使用自適應均衡

    電子發燒友網站提供《TDP1204和TMDS1204如何使用自適應均衡.pdf》資料免費下載
    發表于 09-11 10:28 ?0次下載
    TDP1204和TMDS1204如何使用<b class='flag-5'>自適應</b>均衡

    TUSB1146的自適應均衡帶來的益處

    電子發燒友網站提供《TUSB1146的自適應均衡帶來的益處.pdf》資料免費下載
    發表于 09-03 10:56 ?0次下載
    TUSB1146的<b class='flag-5'>自適應</b>均衡帶來的益處

    并發物聯網云平臺是什么

    并發物聯網云平臺是種能夠處理大量設備同時連接并進行數據交換的云計算平臺。這種平臺通常被設計用來應對來自數以萬計甚至數十億計的物聯網設備的并發
    的頭像 發表于 08-13 13:50 ?265次閱讀

    并發系統的藝術:如何在流量洪峰中游刃有余

    尤為重要。用戶對在線服務的需求和期望不斷提高,系統的并發處理能力成為衡量其性能和用戶體驗的關鍵指標之一并發系統不僅僅是大型互聯網企業的專利,對于任何希望在市場中占據
    的頭像 發表于 08-05 13:43 ?294次閱讀
    <b class='flag-5'>高</b><b class='flag-5'>并發</b>系統的藝術:如何在流量洪峰中游刃有余

    ALINX受邀參加AMD自適應計算峰會

    近日,AMD 自適應計算峰會(AMD Adaptive Computing Summit, 即 AMD ACS)在深圳舉行,聚焦 AMD 自適應 SoC 和 FPGA 產品最新動態,以及設計工具和開發環境的前沿技巧,是全球硬件開發者和工程師們深入交流與學習的優質平臺。
    的頭像 發表于 08-02 14:36 ?624次閱讀

    如何在自己的固件中增加wifi自適應性相關功能,以通過wifi自適應認證測試?

    目前官方提供了自適應測試固件 ESP_Adaptivity_v2.0_26M_20160322.bin 用于進行 wifi 自適應認證測試. 請問如何在自己的固件中增加 wifi 自適應性相關功能,以通過 wifi
    發表于 07-12 08:29

    鴻蒙OS開發:【次開發,多端部署】(自適應布局)

    針對常見的開發場景,方舟開發框架提煉了七種自適應布局能力,這些布局可以獨立使用,也可多種布局疊加使用。
    的頭像 發表于 05-25 16:36 ?1709次閱讀
    鴻蒙OS開發:【<b class='flag-5'>一</b>次開發,多端部署】(<b class='flag-5'>自適應</b>布局)

    鴻蒙OS開發:【次開發,多端部署】應用(自適應布局)

    針對常見的開發場景,方舟開發框架提煉了七種自適應布局能力,這些布局可以獨立使用,也可多種布局疊加使用。
    的頭像 發表于 05-24 10:34 ?1048次閱讀
    鴻蒙OS開發:【<b class='flag-5'>一</b>次開發,多端部署】應用(<b class='flag-5'>自適應</b>布局)

    請問ST25RU3993-HPEV的自適應防碰撞算法是在板子上面實現的嗎?

    請問ST25RU3993-HPEV的自適應防碰撞算法是在板子上面實現的?還是在STSW-ST25RU001上位機上面實現的?這個算法可否提供?STSW-ST25
    發表于 03-19 06:50

    什么是自適應光學?自適應光學原理與方法的發展

    目前,世界上大型的望遠鏡系統都采用了自適應光學技術,自適應光學的出現為補償動態波前擾動,提高光波質量提供了新的研究方向。 60多年來,自適應光學技術獲得蓬勃發展,現已應用于天文學、空間光學、激光、生物醫學等領域。
    發表于 03-11 10:27 ?2115次閱讀

    TCP協議技術之自適應重傳

    自適應重傳是TCP協議中的種擁塞控制機制,旨在通過智能的方式處理網絡擁塞,并進行相應的數據重傳,以提高網絡的可靠性和性能。
    的頭像 發表于 02-03 17:03 ?1543次閱讀
    TCP協議技術之<b class='flag-5'>自適應</b>重傳

    AMD率先推出符合DisplayPort? 2.1 8K視頻標準的FPGA和自適應SoC

    AMD UltraScale+ FPGA 和 AMD Versal 自適應 SoC 產品系列已率先成為業界符合 VESA DisplayPort 2.1 標準的 FPGA 和自適應 SoC。
    的頭像 發表于 01-24 09:18 ?472次閱讀
    主站蜘蛛池模板: 草草久久久亚洲AV成人片| 亚洲AV中文字幕无码久久 | 在线看片成人免费视频| 国产69精品久久久久人妻刘玥| 男gv纯肉免费视频| 1000部做羞羞事禁片免费视频网站| qvod 艺术片| 精品高清国产a毛片| 性一交一乱一色一视频| 国产福利不卡在线视频| 跳蛋按摩棒玉势PLAY高H| 国产v综合v亚洲欧美大片| 涩涩在线视频| 做你的爱人BD日本| 久久视频在线视频观看天天看视频| 亚洲国产精品特色大片观看| 国外色幼网| 依恋影院在线观看| 久久精品国产99欧美精品亚洲| 正能量不良WWW免费窗口| 老司机福利视频一区在线播放| 123成人站| 欧美无码专区| 囯产免费久久久久久国产免费 | 妖精视频免费高清观看| 久久久久久电影| 99国产在线视频| 日日噜噜夜夜爽爽| xlxx美女| 无码乱人伦一区二区亚洲| 国产精品国产三级国产AV麻豆| 乌克兰18性hd| 精品一区二区三区色花堂| 总裁呻吟双腿大开男男H| 欧美aa级片| 国产MD视频一区二区三区| 亚洲AV美女成人网站P站| 久久久无码精品亚洲A片软件 | 2020年国产精品午夜福利在线观看| 国产乱人视频在线观看| 亚洲欧洲无码AV在线观看你懂的|