溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》
  • 首頁 > 
  • 教程 > 
  • 服務(wù)器 > 
  • Nginx如何實(shí)現(xiàn)對網(wǎng)段內(nèi)ip的連接數(shù)限流配置

Nginx如何實(shí)現(xiàn)對網(wǎng)段內(nèi)ip的連接數(shù)限流配置

發(fā)布時(shí)間:2021-08-20 14:17:13 來源:億速云 閱讀:172 作者:小新 欄目:服務(wù)器

這篇文章主要介紹了Nginx如何實(shí)現(xiàn)對網(wǎng)段內(nèi)ip的連接數(shù)限流配置,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Nginx中的所謂連接數(shù)限制,其實(shí)是tcp連接,也就是請求方通過三次握手后成功建立的連接狀態(tài)。Nginx一般為我們提供了 ngx_http_limit_conn_module 模塊來提供限制連接功能。該模塊可以根據(jù)定義的鍵來限制每個(gè)鍵值的連接數(shù),如同一個(gè)IP來源的連接數(shù)。

ngx_http_limit_conn_module指令解釋

Syntax:  limit_conn zone number;
Default:  —
Context:  http, server, location

該指令描述會(huì)話狀態(tài)存儲(chǔ)區(qū)域。鍵的狀態(tài)中保存了當(dāng)前連接數(shù),鍵的值可以是特定變量的任何非空值(空值將不會(huì)被考慮)。$variable定義鍵,zone=name定義區(qū)域名稱。 常見使用例子:

limit_conn_zone $binary_remote_addr zone=addr:10m;

server {
  location /download/ {
    limit_conn addr 1;
  }

上面例子表示當(dāng)請求訪問 /download/ 時(shí), 同一時(shí)刻只能一個(gè)請求連接會(huì)成功進(jìn)行資源下載。

網(wǎng)段限制

常見的limit_conn_zone 配置一般設(shè)置 $binary_remote_addr 或 $server_name,進(jìn)行單一ip或主機(jī)級的連接數(shù)限制。

但有時(shí)候我們希望能對某ip網(wǎng)段進(jìn)行連接數(shù)限制,那我們可以這么做:

http {

... ...

  limit_conn_zone $ip_segment zone=network_segment:10m;

  server {
      ... ...
      set $ip_segment $remote_addr;

      if ( $ip_segment ~ ^(\d+)\.(\d+)\.(\d+)\.(\d+) ) {
        set $ip_segment $1.$2.$3;
      }

      location /download/ {
        limit_conn network_segment 10; 
        #limit_rate 200k;
      }

  }
}

這樣基本能滿足Nginx對網(wǎng)段內(nèi)所有ip的連接數(shù)做統(tǒng)一的連接數(shù)限制了。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Nginx如何實(shí)現(xiàn)對網(wǎng)段內(nèi)ip的連接數(shù)限流配置”這篇文章對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

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

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

AI