溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Nginx限流如何配置

發(fā)布時(shí)間:2022-05-21 11:41:01 來源:億速云 閱讀:314 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容介紹了“Nginx限流如何配置”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

空桶

我們從最簡(jiǎn)單的限流配置開始:

limit_req_zone $binary_remote_addr zone=ip_limit:10m rate=10r/s;

server {
  location /login/ {
    limit_req zone=ip_limit;
    proxy_pass http://login_upstream;
  }
}
  • $binary_remote_addr 針對(duì)客戶端ip限流;

  • zone=ip_limit:10m 限流規(guī)則名稱為ip_limit,允許使用10mb的內(nèi)存空間來記錄ip對(duì)應(yīng)的限流狀態(tài);

  • rate=10r/s 限流速度為每秒10次請(qǐng)求

  • location /login/ 對(duì)登錄進(jìn)行限流

限流速度為每秒10次請(qǐng)求,如果有10次請(qǐng)求同時(shí)到達(dá)一個(gè)空閑的nginx,他們都能得到執(zhí)行嗎?

Nginx限流如何配置

漏桶漏出請(qǐng)求是勻速的。10r/s是怎樣勻速的呢?每100ms漏出一個(gè)請(qǐng)求。

在這樣的配置下,桶是空的,所有不能實(shí)時(shí)漏出的請(qǐng)求,都會(huì)被拒絕掉。

所以如果10次請(qǐng)求同時(shí)到達(dá),那么只有一個(gè)請(qǐng)求能夠得到執(zhí)行,其它的,都會(huì)被拒絕。

這不太友好,大部分業(yè)務(wù)場(chǎng)景下我們希望這10個(gè)請(qǐng)求都能得到執(zhí)行。

burst

我們把配置改一下,解決上一節(jié)的問題

limit_req_zone $binary_remote_addr zone=ip_limit:10m rate=10r/s;

server {
  location /login/ {
    limit_req zone=ip_limit burst=12;
    proxy_pass http://login_upstream;
  }
}

burst=12 漏桶的大小設(shè)置為12

Nginx限流如何配置

邏輯上叫漏桶,實(shí)現(xiàn)起來是fifo隊(duì)列,把得不到執(zhí)行的請(qǐng)求暫時(shí)緩存起來。

這樣漏出的速度仍然是100ms一個(gè)請(qǐng)求,但并發(fā)而來,暫時(shí)得不到執(zhí)行的請(qǐng)求,可以先緩存起來。只有當(dāng)隊(duì)列滿了的時(shí)候,才會(huì)拒絕接受新請(qǐng)求。

這樣漏桶在限流的同時(shí),也起到了削峰填谷的作用。

在這樣的配置下,如果有10次請(qǐng)求同時(shí)到達(dá),它們會(huì)依次執(zhí)行,每100ms執(zhí)行1個(gè)。

雖然得到執(zhí)行了,但因?yàn)榕抨?duì)執(zhí)行,延遲大大增加,在很多場(chǎng)景下仍然是不能接受的。

nodelay

繼續(xù)修改配置,解決delay太久導(dǎo)致延遲增加的問題

limit_req_zone $binary_remote_addr zone=ip_limit:10m rate=10r/s;

server {
  location /login/ {
    limit_req zone=ip_limit burst=12 nodelay;
    proxy_pass http://login_upstream;
  }
}

nodelay 把開始執(zhí)行請(qǐng)求的時(shí)間提前,以前是delay到從桶里漏出來才執(zhí)行,現(xiàn)在不delay了,只要入桶就開始執(zhí)行

Nginx限流如何配置

要么立刻執(zhí)行,要么被拒絕,請(qǐng)求不會(huì)因?yàn)橄蘖鞫黾友舆t了。

因?yàn)檎?qǐng)求從桶里漏出來還是勻速的,桶的空間又是固定的,最終平均下來,還是每秒執(zhí)行了5次請(qǐng)求,限流的目的還是達(dá)到了。

但這樣也有缺點(diǎn),限流是限了,但是限得不那么勻速。以上面的配置舉例,如果有12個(gè)請(qǐng)求同時(shí)到達(dá),那么這12個(gè)請(qǐng)求都能夠立刻執(zhí)行,然后后面的請(qǐng)求只能勻速進(jìn)桶,100ms執(zhí)行1個(gè)。如果有一段時(shí)間沒有請(qǐng)求,桶空了,那么又可能出現(xiàn)并發(fā)的12個(gè)請(qǐng)求一起執(zhí)行。

大部分情況下,這種限流不勻速,不算是大問題。不過nginx也提供了一個(gè)參數(shù)才控制并發(fā)執(zhí)行也就是nodelay的請(qǐng)求的數(shù)量。

limit_req_zone $binary_remote_addr zone=ip_limit:10m rate=10r/s;

server {
  location /login/ {
    limit_req zone=ip_limit burst=12 delay=4;
    proxy_pass http://login_upstream;
  }
}

delay=4 從桶內(nèi)第5個(gè)請(qǐng)求開始delay

Nginx限流如何配置

這樣通過控制delay參數(shù)的值,可以調(diào)整允許并發(fā)執(zhí)行的請(qǐng)求的數(shù)量,使得請(qǐng)求變的均勻起來,在有些耗資源的服務(wù)上控制這個(gè)數(shù)量,還是有必要的。

“Nginx限流如何配置”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI