欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解nginx的請(qǐng)求限制(連接限制和請(qǐng)求限制)

 更新時(shí)間:2018年07月12日 13:46:16   作者:浮生夢(mèng)  
這篇文章主要介紹了詳解nginx的請(qǐng)求限制(連接限制和請(qǐng)求限制),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

一,背景

    我們經(jīng)常會(huì)遇到這種情況,服務(wù)器流量異常,負(fù)載過大等等。對(duì)于大流量惡意的攻擊訪問,會(huì)帶來帶寬的浪費(fèi),服務(wù)器壓力,影響業(yè)務(wù),往往考慮對(duì)同一個(gè)ip的連接數(shù),并發(fā)數(shù)進(jìn)行限制。http_limit_conn_module 模塊來實(shí)現(xiàn)。該模塊可以根據(jù)定義的鍵來限制每個(gè)鍵值的連接數(shù),如同一個(gè)IP來源的連接數(shù)。并不是所有的連接都會(huì)被該模塊計(jì)數(shù),只有那些正在被處理的請(qǐng)求(這些請(qǐng)求的頭信息已被完全讀入)所在的連接才會(huì)被計(jì)數(shù)。http_limit_req_module 模塊來實(shí)現(xiàn),該模塊可以通過定義的 鍵值來限制請(qǐng)求處理的頻率。特別的,可以限制來自單個(gè)IP地址的請(qǐng)求處理頻率。 限制的方法如同漏斗,每秒固定處理請(qǐng)求數(shù),推遲過多請(qǐng)求。

二,配置語法

1,http_limit_conn_module指令解釋

limit_conn_zone
語法: limit_conn_zone $variable zone=name:size;
默認(rèn)值: none
配置段: http

該指令描述會(huì)話狀態(tài)存儲(chǔ)區(qū)域。鍵的狀態(tài)中保存了當(dāng)前連接數(shù),鍵的值可以是特定變量的任何非空值(空值將不會(huì)被考慮)。$variable定義鍵,zone=name定義區(qū)域名稱,后面的limit_conn指令會(huì)用到的。size定義各個(gè)鍵共享內(nèi)存空間大小。如:

limit_conn_zone $binary_remote_addr zone=addr:10m;

注釋:客戶端的IP地址作為鍵。注意,這里使用的是$binary_remote_addr變量,而不是$remote_addr變量。

$remote_addr變量的長(zhǎng)度為7字節(jié)到15字節(jié),而存儲(chǔ)狀態(tài)在32位平臺(tái)中占用32字節(jié)或64字節(jié),在64位平臺(tái)中占用64字節(jié)。

$binary_remote_addr變量的長(zhǎng)度是固定的4字節(jié),存儲(chǔ)狀態(tài)在32位平臺(tái)中占用32字節(jié)或64字節(jié),在64位平臺(tái)中占用64字節(jié)。

1M共享空間可以保存3.2萬個(gè)32位的狀態(tài),1.6萬個(gè)64位的狀態(tài)。

如果共享內(nèi)存空間被耗盡,服務(wù)器將會(huì)對(duì)后續(xù)所有的請(qǐng)求返回 503 (Service Temporarily Unavailable) 錯(cuò)誤。

limit_zone 指令和limit_conn_zone指令同等意思,已經(jīng)被棄用,就不再做說明了。

limit_conn_log_level
語法:limit_conn_log_level info | notice | warn | error
默認(rèn)值:error

配置段:http, server, location

當(dāng)達(dá)到最大限制連接數(shù)后,記錄日志的等級(jí)。

limit_conn
語法:limit_conn zone_name number
默認(rèn)值:none
配置段:http, server, location

指定每個(gè)給定鍵值的最大同時(shí)連接數(shù),當(dāng)超過這個(gè)數(shù)字時(shí)被返回503 (Service Temporarily Unavailable)錯(cuò)誤。如:

limit_conn_zone $binary_remote_addrzone=addr:10m;
server{
 location /www.baidu.com/{
  limit_conn addr 1;
 }
}

同一IP同一時(shí)間只允許有一個(gè)連接。

當(dāng)多個(gè) limit_conn 指令被配置時(shí),所有的連接數(shù)限制都會(huì)生效。比如,下面配置不僅會(huì)限制單一IP來源的連接數(shù),同時(shí)也會(huì)限制單一虛擬服務(wù)器的總連接數(shù):

limit_conn_zone $binary_remote_addr zone=perip:10m;
limit_conn_zone $server_name zone=perserver:10m;
server {
 limit_conn perip 10;
 limit_conn perserver 100;
}

[warning]limit_conn指令可以從上級(jí)繼承下來。[/warning]

limit_conn_status
語法: limit_conn_status code;
默認(rèn)值: limit_conn_status 503;
配置段: http, server, location

該指定在1.3.15版本引入的。指定當(dāng)超過限制時(shí),返回的狀態(tài)碼。默認(rèn)是503。

limit_rate
語法:limit_rate rate
默認(rèn)值:0
配置段:http, server, location, if in location

對(duì)每個(gè)連接的速率限制。參數(shù)rate的單位是字節(jié)/秒,設(shè)置為0將關(guān)閉限速。 按連接限速而不是按IP限制,因此如果某個(gè)客戶端同時(shí)開啟了兩個(gè)連接,那么客戶端的整體速率是這條指令設(shè)置值的2倍。

完整實(shí)例配置

http{
 limit_conn_zone$binary_remote_addrzone=limit:10m;
 limit_conn_log_level info;
 server{
  location ^~/download/{ 
  limit_conn limit 4;
  limit_rate 200k;
  /data/www.baidu.com/download/;
  }
 }
}

使用注意事項(xiàng)

事務(wù)都具有兩面性的。http_limit_conn_module 模塊雖說可以解決當(dāng)前面臨的并發(fā)問題,但是會(huì)引入另外一些問題的。如前端如果有做LVS或反代,而我們后端啟用了該模塊功能,那不是非常多503錯(cuò)誤了?這樣的話,可以在前端啟用該模塊,要么就是設(shè)置白名單,白名單設(shè)置參見后續(xù)的文檔。

2,ngx_http_limit_req_module模塊指令

limit_req_zone
語法: limit_req_zone $variable zone=name:size rate=rate;
默認(rèn)值: none
配置段: http

設(shè)置一塊共享內(nèi)存限制域用來保存鍵值的狀態(tài)參數(shù)。 特別是保存了當(dāng)前超出請(qǐng)求的數(shù)量。 鍵的值就是指定的變量(空值不會(huì)被計(jì)算)。如

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

說明:區(qū)域名稱為one,大小為10m,平均處理的請(qǐng)求頻率不能超過每秒一次。
鍵值是客戶端IP。

使用$binary_remote_addr變量, 可以將每條狀態(tài)記錄的大小減少到64個(gè)字節(jié),這樣1M的內(nèi)存可以保存大約1萬6千個(gè)64字節(jié)的錄。

如果限制域的存儲(chǔ)空間耗盡了,對(duì)于后續(xù)所有請(qǐng)求,服務(wù)器都會(huì)返回 503 (Service Temporarily Unavailable)錯(cuò)誤。
速度可以設(shè)置為每秒處理請(qǐng)求數(shù)和每分鐘處理請(qǐng)求數(shù),其值必須是整數(shù),所以如果你需要指定每秒處理少于1個(gè)的請(qǐng)求,2秒處理一個(gè)請(qǐng)求,可以使用 “30r/m”。

limit_req_log_level
語法: limit_req_log_level info | notice | warn | error;
默認(rèn)值: limit_req_log_level error;
配置段: http, server, location

設(shè)置你所希望的日志級(jí)別,當(dāng)服務(wù)器因?yàn)轭l率過高拒絕或者延遲處理請(qǐng)求時(shí)可以記下相應(yīng)級(jí)別的日志。 延遲記錄的日志級(jí)別比拒絕的低一個(gè)級(jí)別;比如, 如果設(shè)置“l(fā)imit_req_log_level notice”, 延遲的日志就是info級(jí)別。

limit_req_status
語法: limit_req_status code;
默認(rèn)值: limit_req_status 503;
配置段: http, server, location

該指令在1.3.15版本引入。設(shè)置拒絕請(qǐng)求的響應(yīng)狀態(tài)碼。

limit_req
語法: limit_req zone=name [burst=number] [nodelay];
默認(rèn)值: —
配置段: http, server, location

設(shè)置對(duì)應(yīng)的共享內(nèi)存限制域和允許被處理的最大請(qǐng)求數(shù)閾值。 如果請(qǐng)求的頻率超過了限制域配置的值,請(qǐng)求處理會(huì)被延遲,所以所有的請(qǐng)求都是以定義的頻率被處理的。 超過頻率限制的請(qǐng)求會(huì)被延遲,直到被延遲的請(qǐng)求數(shù)超過了定義的閾值,這時(shí),這個(gè)請(qǐng)求會(huì)被終止,并返回503 (Service Temporarily Unavailable) 錯(cuò)誤。這個(gè)閾值的默認(rèn)值為0。如:

limit_req_zone $binary_remote_addr zone=creq:10 mrate=1r/s;
server{
 location /www.baidu.com/{
  limit_req zone=creq burst=5;
 }
}

限制平均每秒不超過一個(gè)請(qǐng)求,同時(shí)允許超過頻率限制的請(qǐng)求數(shù)不多于5個(gè)。

如果不希望超過的請(qǐng)求被延遲,可以用nodelay參數(shù),如:

limit_req zone=ttlsa_com burst=5 nodelay;

完整實(shí)例配置

http{
 limit_req_zone $binary_remote_addr zone=creq:10m rate=1r/s;
 server{
  location ^~/download/{ 
  limit_req zone=creq burst=5;
  data/www.baidu.com/download/;
  }
 }
}

可能要對(duì)某些IP不做限制,需要使用到白名單。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Linux上搭載Nginx負(fù)載均衡配置使用案例詳解

    Linux上搭載Nginx負(fù)載均衡配置使用案例詳解

    這篇文章主要介紹了Linux上搭載Nginx負(fù)載均衡配置使用案例詳解,針對(duì)此情況而衍生出來的一種廉價(jià)有效透明的方法以擴(kuò)展現(xiàn)有網(wǎng)絡(luò)設(shè)備和服務(wù)器的帶寬、增加吞吐量、加強(qiáng)網(wǎng)絡(luò)數(shù)據(jù)處理能力、提高網(wǎng)絡(luò)的靈活性和可用性的技術(shù)就是負(fù)載均衡(Load?Balance),需要的朋友可以參考下
    2022-01-01
  • Nginx虛擬主機(jī)的配置實(shí)現(xiàn)

    Nginx虛擬主機(jī)的配置實(shí)現(xiàn)

    虛擬主機(jī)指的就是一個(gè)獨(dú)立的站點(diǎn)配置,是nginx默認(rèn)支持的一個(gè)功能,本文主要介紹了Nginx虛擬主機(jī)的配置實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01
  • nginx修改默認(rèn)端口方法圖文詳解

    nginx修改默認(rèn)端口方法圖文詳解

    我們都知道nginx 默認(rèn)使用80端口,有時(shí)候我們希望nginx運(yùn)行在其他端口,下面這篇文章主要給大家介紹了關(guān)于nginx修改默認(rèn)端口的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Nginx服務(wù)安裝及軟件升級(jí)

    Nginx服務(wù)安裝及軟件升級(jí)

    這篇文章主要為大家介紹了Nginx服務(wù)的安裝以及軟件升級(jí)的步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • nginx實(shí)現(xiàn)靜態(tài)文件的token認(rèn)證過程

    nginx實(shí)現(xiàn)靜態(tài)文件的token認(rèn)證過程

    這篇文章主要介紹了nginx實(shí)現(xiàn)靜態(tài)文件的token認(rèn)證過程,
    2024-06-06
  • 深入淺析nginx部署及簡(jiǎn)單優(yōu)化

    深入淺析nginx部署及簡(jiǎn)單優(yōu)化

    Nginx是lgor Sysoev為俄羅斯訪問量第二的rambler.ru站點(diǎn)設(shè)計(jì)開發(fā)的。本文重點(diǎn)給大家介紹nginx部署及簡(jiǎn)單優(yōu)化方案,感興趣的朋友一起看看吧
    2018-08-08
  • Nginx+Tomcat負(fù)載均衡集群的實(shí)現(xiàn)示例

    Nginx+Tomcat負(fù)載均衡集群的實(shí)現(xiàn)示例

    本文主要介紹了Nginx + Tomcat負(fù)載均衡集群的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Nginx中server_name指令的參數(shù)詳解

    Nginx中server_name指令的參數(shù)詳解

    這篇文章主要介紹了Nginx中server_name指令的參數(shù)詳解,Nginx中的server_name指令主要用于配置基于名稱的虛擬主機(jī),server_name指令一項(xiàng)很實(shí)用的功能便是可以在使用正則表達(dá)式的捕獲功能,這樣可以盡量精簡(jiǎn)配置文件,需要的朋友可以參考下
    2023-08-08
  • Nginx結(jié)合keepalived實(shí)現(xiàn)雙機(jī)熱備方案

    Nginx結(jié)合keepalived實(shí)現(xiàn)雙機(jī)熱備方案

    Nginx難免遇見故障,可以使用使用keepalived來實(shí)現(xiàn)Nginx的高可用,本文主要介紹了Nginx結(jié)合keepalived實(shí)現(xiàn)雙機(jī)熱備方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-05-05
  • 簡(jiǎn)介Nginx服務(wù)器的Websockets配置方法

    簡(jiǎn)介Nginx服務(wù)器的Websockets配置方法

    這篇文章主要介紹了簡(jiǎn)介Nginx服務(wù)器的Websockets配置方法,是使用Nginx服務(wù)器的網(wǎng)管的必備知識(shí)XD~需要的朋友可以參考下
    2015-06-06

最新評(píng)論