自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

億級流量網(wǎng)站架構(gòu)核心技術(shù):限流詳解之節(jié)流

開發(fā) 開發(fā)工具
有時候我們想在特定時間窗口內(nèi)對重復(fù)的相同事件最多只處理一次,或者想限制多個連續(xù)相同事件最小執(zhí)行時間間隔,那么可使用節(jié)流(Throttle)實現(xiàn),其防止多個相同事件連續(xù)重復(fù)執(zhí)行。

上接聊聊高并發(fā)系統(tǒng)之限流特技-1、聊聊高并發(fā)系統(tǒng)之限流特技-2,本篇摘自《億級流量網(wǎng)站架構(gòu)核心技術(shù)》第四章 限流詳解,在之前兩篇文章的基礎(chǔ)上增加了節(jié)流部分。

有時候我們想在特定時間窗口內(nèi)對重復(fù)的相同事件最多只處理一次,或者想限制多個連續(xù)相同事件最小執(zhí)行時間間隔,那么可使用節(jié)流(Throttle)實現(xiàn),其防止多個相同事件連續(xù)重復(fù)執(zhí)行。節(jié)流主要有如下幾種用法:throttleFirst、throttleLast、throttleWithTimeout。

1. throttleFirst/throttleLast

throttleFirst/ throttleLast是指在一個時間窗口內(nèi),如果有重復(fù)的多個相同事件要處理,則只處理***個或***一個。其相當(dāng)于一個事件頻率控制器,把一段時間內(nèi)重復(fù)的多個相同事件變?yōu)橐粋€,減少事件處理頻率,從而減少無用處理,提升性能。

throttleFirst在一個時間窗口內(nèi)只會處理該時間窗口內(nèi)的***個事件

如上圖所示,throttleFirst在一個時間窗口內(nèi)只會處理該時間窗口內(nèi)的***個事件。

而throttleLast會處理該時間窗口內(nèi)的***一個事件。

一個場景是網(wǎng)頁中的resize、scroll和mousemove 事件,當(dāng)我們改變?yōu)g覽器大小時會觸發(fā)resize事件,而滾動頁面元素時會觸發(fā)scroll事件。當(dāng)我們快速連續(xù)執(zhí)行這些操作時會連續(xù)觸發(fā)這些事件,那么可能因造成UI反應(yīng)慢、瀏覽器卡頓,因此節(jié)流就派上用場了。對于前端開發(fā)可以使用jquery-throttle-debounce-plugin實現(xiàn),而Android開發(fā)可以使用RxAndroid實現(xiàn)。

2 throttleWithTimeout

throttleWithTimeout也叫做debounce(去抖),限制兩個連續(xù)事件的先后執(zhí)行時間不得小于某個時間窗口。

throttleWithTimeout限制兩個連續(xù)事件的最小間隔時間窗口

如上圖所示,throttleWithTimeout限制兩個連續(xù)事件的最小間隔時間窗口。throttleFirst/ throttleLast是基于決定時間做的處理,是以固定時間窗口為基準(zhǔn),對同一個固定時間窗口內(nèi)的多個連續(xù)事件最多只處理一個。而throttleWithTimeout是基于兩個連續(xù)事件的相對時間,當(dāng)兩個連續(xù)事件的間隔時間小于最小間隔時間窗口,就會丟棄上一個事件,而如果***一個事件等待了最小間隔時間窗口后還沒有新的事件到來,那么會處理***一個事件。

如搜索關(guān)鍵詞自動補全,如果用戶每錄入一個字就發(fā)送一次請求,而先輸入的字的自動補全會被很快到來的下一個字符覆蓋,那么會導(dǎo)致先期的自動補全是無用的。throttleWithTimeout就是來解決這個問題的,通過它來減少頻繁的網(wǎng)絡(luò)請求,避免每輸入一個字就導(dǎo)致一次請求。

使用RxJava 1.2.0實現(xiàn)的測試代碼。

  1. Observable 
  2.         .create(new Observable.OnSubscribe<Integer>(){ 
  3.             @Override 
  4.             public void call(Subscriber<? super Integer> subscriber) { 
  5.                 //next實現(xiàn):Thread.sleep(millis); subscriber.onNext(i); 
  6.                 next(subscriber, 1,0);  //0ms 
  7.                 next(subscriber, 2,50); //50ms 
  8.                 next(subscriber, 3,50); //100ms 
  9.                 next(subscriber, 4,30); //130ms 
  10.                 next(subscriber, 5, 40); //170ms 
  11.                 next(subscriber, 6,130); //300ms 
  12.                 subscriber.onCompleted(); 
  13.             } 
  14.         }) 
  15.         .subscribeOn(Schedulers.newThread()) 
  16.         .throttleWithTimeout(100,TimeUnit.MILLISECONDS) 
  17.         .subscribe(new Subscriber<Integer>() { 
  18.             …… 
  19.             @Override 
  20.             public void onNext(Integer i) { 
  21.                 System.out.println("==" + i); 
  22.             } 
  23.         }); 

【本文是51CTO專欄作者張開濤的原創(chuàng)文章,作者微信公眾號:開濤的博客( kaitao-1234567)】

戳這里,看該作者更多好文

責(zé)任編輯:趙寧寧 來源: 51CTO專欄
相關(guān)推薦

2025-04-22 08:57:27

2016-11-30 13:23:39

京東商品搜索商品搜索引擎

2021-10-12 10:00:25

架構(gòu)運維技術(shù)

2021-12-03 10:47:28

WOT技術(shù)峰會技術(shù)

2025-02-26 00:28:01

2021-10-14 09:51:17

架構(gòu)運維技術(shù)

2020-01-17 11:00:23

流量系統(tǒng)架構(gòu)

2023-06-14 08:49:22

PodKubernetes

2017-03-08 10:06:11

Java技術(shù)點注解

2016-12-12 09:01:47

Amazon Go核心技術(shù)

2022-10-11 08:37:43

Servlet配置版本

2016-11-23 12:55:09

京東活動系統(tǒng)流量

2024-08-23 11:38:05

2021-03-02 07:54:18

流量網(wǎng)關(guān)設(shè)計

2022-05-07 14:31:46

物聯(lián)網(wǎng)

2017-04-06 12:43:48

2011-08-23 17:12:22

MySQL支撐百萬級流

2020-09-01 07:49:14

JVM流量系統(tǒng)

2024-05-27 08:32:45

2022-05-09 08:21:29

Spring微服務(wù)Sentinel
點贊
收藏

51CTO技術(shù)棧公眾號