真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Nginx如何限制訪問頻率,下載速率和并發(fā)連接數(shù)的方法

一、 限制訪問頻率、并發(fā)連接、下載速度用到的模塊和指令概述

創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),沽源企業(yè)網(wǎng)站建設(shè),沽源品牌網(wǎng)站建設(shè),網(wǎng)站定制,沽源網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,沽源網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

  • ngx_http_limit_req_module :用來限制單位時(shí)間內(nèi)的請求數(shù),即速率限制,采用的漏桶算法 “l(fā)eaky bucket”
  • ngx_http_limit_conn_module :用來限制同一時(shí)間連接數(shù),即并發(fā)限制
  • limit_rate和limit_rate_after :下載速度設(shè)置

漏桶算法(leaky bucket)

Nginx 如何限制訪問頻率,下載速率和并發(fā)連接數(shù)的方法

算法思想是:

  • 水(請求)從上方倒入水桶,從水桶下方流出(被處理)
  • 來不及流出的水存在水桶中(緩沖),以固定速率流出;
  • 水桶滿后水溢出(丟棄)。
  • 這個(gè)算法的核心是:緩存請求、勻速處理、多余的請求直接丟棄。
  • Nginx按請求速率限速模塊使用的是漏桶算法,即能夠強(qiáng)行保證請求的實(shí)時(shí)處理速度不會(huì)超過設(shè)置的閾值

二、限制URL訪問請求頻率

http{ 
    ... 
 
  limit_req_zone $binary_remote_addr zone=one:30m rate=20r/s; 
  limit_req_zone $binary_remote_addr $uri zone=two:30m rate=20r/s; 
  limit_req_zone $binary_remote_addr $request_uri zone=three:30m rate=20r/s; 
  limit_req_status 444; 
    ... 
 
  server{ 
      ... 
 
    limit_req zone=two burst=15 nodelay; 
    ... 
 
  } 
} 

解釋:

limit_req_zone $binary_remote_addr zone=one:30m rate=20r/s;

  • $binary_remote_addr 是限制同一客戶端ip地址不同URL
  • zone:區(qū)域名one 存放session30M
  • rate: 每秒鐘請求數(shù)

limit_req_zone $binary_remote_addr $uri zone=two:30m rate=20r/s;

  • $binary_remote_addr $uri 是限制同一客戶端ip地址 相同URL
  • zone:區(qū)域名two 存放session30M
  • rate: 每秒鐘請求數(shù)

limit_req_zone $binary_remote_addr $request_uri zone=three:30m rate=20r/s;

  • $binary_remote_addr $request_uri 是限制同一客戶端ip地址 相同URL
  • zone:區(qū)域名two 存放session30M
  • rate: 每秒鐘請求數(shù)

limit_req zone=two burst=15 nodelay;

  • zone引用 區(qū)域?yàn)閠wo,
  • burst 設(shè)置一個(gè)大小為15的緩沖區(qū),當(dāng)有大量請求(爆發(fā))過來時(shí),訪問超過了上面的限制可以先放到緩沖區(qū)內(nèi)。
  • nodelay 一般是和burst一起使用的,如果設(shè)置了nodelay,當(dāng)訪問超過了頻次而且緩沖區(qū)也滿的情況下會(huì)直接返回503,如果設(shè)置了,則所有大的請求會(huì)等待排隊(duì)

三、并發(fā)連接數(shù)限制

案例一:

http { 
  ... 
 
  limit_conn_log_level error; 
  limit_conn_zone $binary_remote_addr zone=addr:10m; 
  limit_conn_status 503; 
 
  ... 
 
  server { 
 
    ... 
 
    location /download/ { 
      limit_conn addr 1; 單個(gè)客戶端IP限制為1 
    } 
    ... 
 
} 

案例二:

http{ 
limit_conn_zone $binary_remote_addr zone=perip:10m; 
limit_conn_zone $server_name zone=perserver:10m; 
 
  server { 
    ... 
    limit_conn perip 10;  #單個(gè)客戶端ip與服務(wù)器的連接數(shù) 
    limit_conn perserver 100; #限制與服務(wù)器的總連接數(shù) 
  } 
} 

四、限制下載速度

location /download { 
  limit_rate 128k; 
 } 
 
#如果想設(shè)置用戶下載文件的前10m大小時(shí)不限速,大于10m后再以128kb/s限速可以增加以下配內(nèi)容 
 
location /download { 
    limit_rate_after 10m; 
    limit_rate 128k; 
 } 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


分享題目:Nginx如何限制訪問頻率,下載速率和并發(fā)連接數(shù)的方法
標(biāo)題路徑:http://weahome.cn/article/ieeojp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部