Java應(yīng)用限流

在開發(fā)高并發(fā)系統(tǒng)時(shí)捂敌,有三把利器用來保護(hù)系統(tǒng):緩存例诀、降級和限流:
緩存:緩存的目的是提升系統(tǒng)訪問速度和增大系統(tǒng)處理容量
降級:降級是當(dāng)服務(wù)出現(xiàn)問題或者影響到核心流程時(shí)型宙,需要暫時(shí)屏蔽掉响牛,待高峰或者問題解決后再打開
限流:限流的目的是通過對并發(fā)訪問/請求進(jìn)行限速瞬捕,或者對一個(gè)時(shí)間窗口內(nèi)的請求進(jìn)行限速來保護(hù)系統(tǒng)歉嗓,一旦達(dá)到限制速率則可以拒絕服務(wù)丰介、排隊(duì)或等待、降級等處理

常見算法:
1鉴分、計(jì)時(shí)器限流
2哮幢、滑動(dòng)窗口
3、漏桶算法
4志珍、令牌桶算法

計(jì)時(shí)器限流

計(jì)時(shí)器是限流算法中比較簡單的一種算法橙垢,比如:限制一個(gè)接口1分鐘內(nèi)不能超過100次請求,可以在一開始設(shè)置一個(gè)計(jì)數(shù)器伦糯,每當(dāng)接收到請求時(shí)柜某,將計(jì)數(shù)器加1嗽元,如果計(jì)數(shù)器的值大于100并且當(dāng)前請求與第一個(gè)請求的執(zhí)行時(shí)間間隔還在1分鐘內(nèi)的,那就說明請求過多莺琳;如果當(dāng)前請求與第一次請求的時(shí)間間隔超過1分鐘还棱,并且請求次數(shù)沒有超限的,那么重置計(jì)數(shù)器

import org.springframework.data.redis.core.RedisTemplate;
/**
 * 計(jì)數(shù)器限流
 * 限制1分鐘內(nèi)請求100次
 * 弊端:
 * 1惭等、當(dāng)前窗口100個(gè)請求全部集中到結(jié)束點(diǎn)珍手,下個(gè)窗口100個(gè)請求全部集中到起始點(diǎn),臨界點(diǎn)就會(huì)出現(xiàn)請求暴增的情況辞做,可能瞬間壓垮應(yīng)用
 * 2琳要、只適用于單機(jī)應(yīng)用,分布式環(huán)境中無法滿足
 *
 * @author lile
 * @date 2019/7/1618:59
 */
public class CounterLimit {

    //時(shí)間窗口內(nèi)的最大請求數(shù)
    public final int reqCount = 100;

    //時(shí)間窗口內(nèi)的當(dāng)前請求數(shù)
    private int currentReqCount;

    //時(shí)間窗口的長度  單位:ms
    public final int interval = 60 * 1000;

    //當(dāng)前時(shí)間
    public Long currentTimestamp = System.currentTimeMillis();

    public RedisTemplate redisTemplate;

    public final String key = "minute_test";

    /**
     * 計(jì)數(shù)器限流
     *
     * @return
     */
    public boolean grant() {
        Long nowTimestamp = System.currentTimeMillis();
        if (nowTimestamp < currentTimestamp + interval) {
            //在當(dāng)前時(shí)間窗口內(nèi)
            currentReqCount++;
            //判斷當(dāng)前時(shí)間窗口的請求數(shù)是否小于最大的請求限制數(shù)
            return currentReqCount < reqCount;
        }
        //不在當(dāng)前窗口內(nèi)時(shí)秤茅,重置下個(gè)窗口的首次請求時(shí)間及窗口內(nèi)請求數(shù)
        currentReqCount = 1;
        currentTimestamp = nowTimestamp;
        return true;
    }

    /**
     * 滑動(dòng)窗口的限流
     * 保證時(shí)間窗口中的請求數(shù)不超過最大限制數(shù)即可稚补,能平穩(wěn)的控制請求的速率,請求過快會(huì)被拒絕
     * 窗口時(shí)間范圍定為1分鐘框喳,每次接收到請求后重新劃分時(shí)間窗口课幕,當(dāng)前時(shí)間往前的1分鐘范圍為新的時(shí)間窗口
     *
     * @return
     */
    public boolean DuoJiQi() {
        Long nowTimestamp = System.currentTimeMillis();
        if (redisTemplate.opsForZSet().size(key) > 0) {
            //移除不在當(dāng)前時(shí)間窗口的數(shù)據(jù)
            redisTemplate.opsForZSet().removeRangeByScore(key, 0, nowTimestamp - interval);
        } 
        redisTemplate.opsForZSet().add(key, "當(dāng)前請求的唯一ID", nowTimestamp);
        if (redisTemplate.opsForZSet().size(key) > reqCount) {
            //請求超限,禁止提交請求
            return false;
        }
        return true;
    }
}

滑動(dòng)窗口

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末五垮,一起剝皮案震驚了整個(gè)濱河市乍惊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌放仗,老刑警劉巖润绎,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異诞挨,居然都是意外死亡莉撇,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門惶傻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來棍郎,“玉大人,你說我怎么就攤上這事达罗“映牛” “怎么了?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵粮揉,是天一觀的道長。 經(jīng)常有香客問我抚笔,道長扶认,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任殊橙,我火速辦了婚禮辐宾,結(jié)果婚禮上狱从,老公的妹妹穿的比我還像新娘。我一直安慰自己叠纹,他們只是感情好季研,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著誉察,像睡著了一般与涡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上持偏,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天驼卖,我揣著相機(jī)與錄音,去河邊找鬼鸿秆。 笑死酌畜,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的卿叽。 我是一名探鬼主播桥胞,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼考婴!你這毒婦竟也來了贩虾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蕉扮,失蹤者是張志新(化名)和其女友劉穎整胃,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體喳钟,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡屁使,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了奔则。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛮寂。...
    茶點(diǎn)故事閱讀 40,015評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖易茬,靈堂內(nèi)的尸體忽然破棺而出酬蹋,到底是詐尸還是另有隱情,我是刑警寧澤抽莱,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布范抓,位于F島的核電站,受9級特大地震影響食铐,放射性物質(zhì)發(fā)生泄漏匕垫。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一虐呻、第九天 我趴在偏房一處隱蔽的房頂上張望象泵。 院中可真熱鬧寞秃,春花似錦、人聲如沸偶惠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忽孽。三九已至绑改,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間扒腕,已是汗流浹背绢淀。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瘾腰,地道東北人皆的。 一個(gè)月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像蹋盆,于是被迫代替她去往敵國和親费薄。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,969評論 2 355

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