限流算法介紹

高并發(fā)的處理有三個(gè)比較常用的手段痕慢,緩存瓷产,限流和降級(jí)。緩存的使用相信很多開發(fā)者都很了解了吱窝,諸如redis讥邻,memcache等工具都會(huì)活躍在我們的系統(tǒng)當(dāng)中。但是假如在某一時(shí)間段內(nèi)出現(xiàn)了遠(yuǎn)超預(yù)想的流量訪問到系統(tǒng)院峡,例如在搞秒殺活動(dòng)之類的兴使,這樣一來我們應(yīng)該如何保護(hù)業(yè)務(wù)系統(tǒng)呢?

在參加一些秒殺活動(dòng)的時(shí)候照激,我們可以看到发魄,有時(shí)候會(huì)有 系統(tǒng)繁忙,請(qǐng)稍后再試
或者 請(qǐng)稍等 的提示俩垃,那這個(gè)系統(tǒng)就很可能是使用了限流的手段励幼。

限流是限制系統(tǒng)的輸入和輸出流量,以達(dá)到保護(hù)系統(tǒng)的目的口柳。而限流的實(shí)現(xiàn)主要是依靠限流算法苹粟,限流算法主要有4種:
1、固定時(shí)間窗口(計(jì)數(shù)器)跃闹;
2嵌削、滑動(dòng)時(shí)間窗口;
3望艺、令牌桶算法苛秕;
4、漏桶算法找默;

1艇劫、計(jì)數(shù)器

計(jì)數(shù)器就是統(tǒng)計(jì)記錄單位時(shí)間內(nèi)進(jìn)入系統(tǒng)或者某一接口的請(qǐng)求次數(shù),在限定的次數(shù)內(nèi)的請(qǐng)求則正常接收處理惩激,超過次數(shù)的請(qǐng)求則拒絕掉店煞,或者改為異步處理蟹演。


image.png

假設(shè)我們?cè)O(shè)定單位時(shí)間內(nèi)進(jìn)入系統(tǒng)的的最大請(qǐng)求數(shù)為100,如果有超過100個(gè)請(qǐng)求集中在刷新計(jì)數(shù)器的臨界點(diǎn)前后進(jìn)入系統(tǒng)浅缸,而且單位時(shí)間的粒度比較粗的話轨帜,那就容易誤傷很多正常請(qǐng)求。

    // 算法偽代碼
    ++counter;
    if(counter > limit) {
        return '系統(tǒng)繁忙衩椒,請(qǐng)稍后再試';
     }
2蚌父、滑動(dòng)時(shí)間窗口

這個(gè)名稱要跟TCP的窗口滑動(dòng)區(qū)分開來,但是理解之后會(huì)發(fā)現(xiàn)其實(shí)也是有點(diǎn)相似毛萌。
計(jì)數(shù)器算法對(duì)流量的限制比較粗放苟弛,而滑動(dòng)時(shí)間窗口的算法則是對(duì)流量進(jìn)行更加平穩(wěn)的控制。上面的計(jì)數(shù)器的單位時(shí)間是1分鐘阁将,而在使用滑動(dòng)時(shí)間窗口膏秫,可以把1分鐘分成6格,每格時(shí)間長(zhǎng)度是10s做盅,每一格又各自管理一個(gè)計(jì)數(shù)器缤削,單位時(shí)間用一個(gè)長(zhǎng)度為60s的窗口描述。一個(gè)請(qǐng)求進(jìn)入系統(tǒng)吹榴,對(duì)應(yīng)的時(shí)間格子的計(jì)數(shù)器便會(huì)+1亭敢,而每過10s,這個(gè)窗口便會(huì)向右滑動(dòng)一格图筹。只要窗口包括的所有格子的計(jì)數(shù)器總和超過限流上限帅刀,便會(huì)拒絕后面的請(qǐng)求。


image.png
      // 算法偽代碼
      var cellIndex = time % cellNum;
      ++cellCounter[cellIndex];
      var sum = 0;
      for(var i = cellIndex; i >= cellIndex - cellNum; --i) {
          sum += cellCounter[i];
      }
      if(sum > limit) {
            return '系統(tǒng)繁忙远剩,請(qǐng)稍后再試';
      }
3扣溺、漏桶算法

漏桶算法,又稱leaky bucket瓜晤。下圖是wiki上的漏桶圖解:


image.png

一個(gè)系統(tǒng)處理請(qǐng)求锥余,就像一個(gè)固定容量的水桶去溜進(jìn)來的水,同時(shí)也讓水流出去痢掠,但是它無法預(yù)見有多少水流進(jìn)來和水流進(jìn)來的速度哈恰,它只能夠控制從桶底水流出去的速度,多出來的水志群,就只好讓它從桶邊流出去了。這個(gè)從桶底流出去的水就是系統(tǒng)正常處理的請(qǐng)求蛔钙,從旁邊流出去的水就是系統(tǒng)拒絕掉的請(qǐng)求锌云。如此一來,我們只要監(jiān)控系統(tǒng)單位時(shí)間內(nèi)處理請(qǐng)求的速率就可以了吁脱,速率超過上限后的請(qǐng)求都給拒絕掉就可以了桑涎。

      // 算法偽代碼
      ++counter;
      var time = nowTime - (nowTime % interval);
      var rate = counter / time;
      if(rate> limitRate) {
            return '系統(tǒng)繁忙彬向,請(qǐng)稍后再試';
      }
4、令牌桶算法

繼續(xù)wiki圖解攻冷。


image.png

令牌桶即是以一定速率生成token并放入桶中娃胆,請(qǐng)求進(jìn)入系統(tǒng)需要先拿到token才能進(jìn)行業(yè)務(wù)處理,無token的請(qǐng)求則拒絕掉等曼。令牌桶算法實(shí)際上跟漏桶算法很相似里烦,而實(shí)際使用中其實(shí)也不需要另起線程生成token,只需要把握好token生成速率和當(dāng)前應(yīng)該剩余的token數(shù)量即可禁谦。

在時(shí)間點(diǎn)刷新的臨界點(diǎn)上胁黑,只要剩余token足夠,令牌桶算法會(huì)允許對(duì)應(yīng)數(shù)量的請(qǐng)求通過州泊,而后刷新時(shí)間因?yàn)閠oken不足丧蘸,流量也會(huì)被限制在外,這樣就比較好的控制了瞬時(shí)流量遥皂。因此力喷,令牌桶算法也被廣泛使用。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末演训,一起剝皮案震驚了整個(gè)濱河市弟孟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌仇祭,老刑警劉巖披蕉,帶你破解...
    沈念sama閱讀 212,294評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異乌奇,居然都是意外死亡没讲,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,493評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門礁苗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爬凑,“玉大人,你說我怎么就攤上這事试伙∴倚牛” “怎么了?”我有些...
    開封第一講書人閱讀 157,790評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵疏叨,是天一觀的道長(zhǎng)潘靖。 經(jīng)常有香客問我,道長(zhǎng)蚤蔓,這世上最難降的妖魔是什么卦溢? 我笑而不...
    開封第一講書人閱讀 56,595評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上单寂,老公的妹妹穿的比我還像新娘贬芥。我一直安慰自己,他們只是感情好宣决,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,718評(píng)論 6 386
  • 文/花漫 我一把揭開白布蘸劈。 她就那樣靜靜地躺著,像睡著了一般尊沸。 火紅的嫁衣襯著肌膚如雪威沫。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,906評(píng)論 1 290
  • 那天椒丧,我揣著相機(jī)與錄音壹甥,去河邊找鬼。 笑死壶熏,一個(gè)胖子當(dāng)著我的面吹牛句柠,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播棒假,決...
    沈念sama閱讀 39,053評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼溯职,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了帽哑?” 一聲冷哼從身側(cè)響起谜酒,我...
    開封第一講書人閱讀 37,797評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎妻枕,沒想到半個(gè)月后僻族,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,250評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡屡谐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,570評(píng)論 2 327
  • 正文 我和宋清朗相戀三年述么,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片愕掏。...
    茶點(diǎn)故事閱讀 38,711評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡度秘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出饵撑,到底是詐尸還是另有隱情剑梳,我是刑警寧澤,帶...
    沈念sama閱讀 34,388評(píng)論 4 332
  • 正文 年R本政府宣布滑潘,位于F島的核電站垢乙,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏语卤。R本人自食惡果不足惜追逮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,018評(píng)論 3 316
  • 文/蒙蒙 一蓖租、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧羊壹,春花似錦、人聲如沸齐婴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,796評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽柠偶。三九已至情妖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诱担,已是汗流浹背毡证。 一陣腳步聲響...
    開封第一講書人閱讀 32,023評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蔫仙,地道東北人料睛。 一個(gè)月前我還...
    沈念sama閱讀 46,461評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像摇邦,于是被迫代替她去往敵國(guó)和親恤煞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,595評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • 曾經(jīng)在一個(gè)大神的blog里看到這樣一句話:在開發(fā)高并發(fā)系統(tǒng)時(shí)施籍,有三把利器用來保護(hù)系統(tǒng):緩存居扒、降級(jí)和限流。那么何為限...
    Johnsonxu閱讀 1,983評(píng)論 0 4
  • 摘要:在開發(fā)高并發(fā)系統(tǒng)時(shí)有三把利器用來保護(hù)系統(tǒng):緩存丑慎、降級(jí)和限流喜喂。而有些場(chǎng)景并不能用緩存和降級(jí)來解決,因此需有一種...
    落羽成霜丶閱讀 2,150評(píng)論 0 18
  • 聊聊高并發(fā)系統(tǒng)限流特技-1來自開濤的博客 在開發(fā)高并發(fā)系統(tǒng)時(shí)有三把利器用來保護(hù)系統(tǒng):緩存竿裂、降級(jí)和限流玉吁。緩存的目的是...
    meng_philip123閱讀 6,623評(píng)論 1 20
  • 最近一直都在研究壓力測(cè)試客戶端的問題,如果突破客戶端壓力測(cè)試線程铛绰,端口等問題诈茧,如果服務(wù)器端處理網(wǎng)絡(luò)請(qǐng)求處理不過來,...
    望月成三人閱讀 8,635評(píng)論 1 25
  • 緩存 緩存比較好理解捂掰,在大型高并發(fā)系統(tǒng)中敢会,如果沒有緩存數(shù)據(jù)庫將分分鐘被爆,系統(tǒng)也會(huì)瞬間癱瘓这嚣。使用緩存不單單能夠提升...
    阿斯蒂芬2閱讀 12,136評(píng)論 1 28