亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 基于Nginx實現限制某IP短時間訪問次數

基于Nginx實現限制某IP短時間訪問次數

熱門標簽:宿州外呼系統公司 陜西辦理400電話 地圖標注小程序 株洲電銷 信陽電銷外呼系統怎么樣 海外工廠地圖標注 南昌外呼系統定制 貴陽網絡外呼系統軟件 南充電銷外呼系統

如何設置能限制某個IP某一時間段的訪問次數是一個讓人頭疼的問題,特別面對惡意的ddos攻擊的時候。其中CC攻擊(Challenge Collapsar)是DDOS(分布式拒絕服務)的一種,也是一種常見的網站攻擊方法,攻擊者通過代理服務器或者肉雞向向受害主機不停地發大量數據包,造成對方服務器資源耗盡,一直到宕機崩潰。

cc攻擊一般就是使用有限的ip數對服務器頻繁發送數據來達到攻擊的目的,nginx可以通過HttpLimitReqModul和HttpLimitZoneModule配置來限制ip在同一時間段的訪問次數來防cc攻擊。

HttpLimitReqModul用來限制連單位時間內連接數的模塊,使用limit_req_zone和limit_req指令配合使用來達到限制。一旦并發連接超過指定數量,就會返回503錯誤。

HttpLimitConnModul用來限制單個ip的并發連接數,使用limit_zone和limit_conn指令

這兩個模塊的區別HttpLimitReqModul是對一段時間內的連接數限制,HttpLimitConnModul是對同一時刻的連接數限制

HttpLimitReqModul 限制某一段時間內同一ip訪問數實例

http{
  ...
  #定義一個名為allips的limit_req_zone用來存儲session,大小是10M內存,
  #以$binary_remote_addr 為key,限制平均每秒的請求為20個,
  #1M能存儲16000個狀態,rete的值必須為整數,
  #如果限制兩秒鐘一個請求,可以設置成30r/m
  limit_req_zone $binary_remote_addr zone=allips:10m rate=20r/s;
  ...
  server{
    ...
    location {
      ...

      #限制每ip每秒不超過20個請求,漏桶數burst為5
      #brust的意思就是,如果第1秒、2,3,4秒請求為19個,
      #第5秒的請求為25個是被允許的。
      #但是如果你第1秒就25個請求,第2秒超過20的請求返回503錯誤。
      #nodelay,如果不設置該選項,嚴格使用平均速率限制請求數,
      #第1秒25個請求時,5個請求放到第2秒執行,
      #設置nodelay,25個請求將在第1秒執行。

      limit_req zone=allips burst=5 nodelay;
      ...
    }
    ...
  }
  ...
}

HttpLimitZoneModule 限制并發連接數實例

limit_zone只能定義在http作用域,limit_conn可以定義在http server location作用域

http{
  ...
  #定義一個名為one的limit_zone,大小10M內存來存儲session,
  #以$binary_remote_addr 為key
  #nginx 1.18以后用limit_conn_zone替換了limit_conn
  #且只能放在http作用域
  limit_conn_zone  one $binary_remote_addr 10m; 
  ...
  server{
    ...
    location {
      ...
      limit_conn one 20;     #連接數限制
      #帶寬限制,對單個連接限數,如果一個ip兩個連接,就是500x2k
      limit_rate 500k;      
      ...
    }
    ...
  }
  ...
}

nginx白名單設置

以上配置會對所有的ip都進行限制,有些時候我們不希望對搜索引擎的蜘蛛或者自己測試ip進行限制,
對于特定的白名單ip我們可以借助geo指令實現。

1.

http{
   geo $limited{
    default 1;
    #google
    64.233.160.0/19 0;
    65.52.0.0/14 0;
    66.102.0.0/20 0;
    66.249.64.0/19 0;
    72.14.192.0/18 0;
    74.125.0.0/16 0;
    209.85.128.0/17 0;
    216.239.32.0/19 0;
    #M$
    64.4.0.0/18 0;
    157.60.0.0/16 0;
    157.54.0.0/15 0;
    157.56.0.0/14 0;
    207.46.0.0/16 0;
    207.68.192.0/20 0;
    207.68.128.0/18 0;
    #yahoo
    8.12.144.0/24 0;
    66.196.64.0/18 0;
    66.228.160.0/19 0;
    67.195.0.0/16 0;
    74.6.0.0/16 0;
    68.142.192.0/18 0;
    72.30.0.0/16 0;
    209.191.64.0/18 0;
    #My IPs
    127.0.0.1/32 0;
    123.456.0.0/28 0; #example for your server CIDR
  }

geo指令定義了一個白名單$limited變量,默認值為1,如果客戶端ip在上面的范圍內,$limited的值為0

2.使用map指令映射搜索引擎客戶端的ip為空串,如果不是搜索引擎就顯示本身真是的ip,這樣搜索引擎ip就不能存到limit_req_zone內存session中,所以不會限制搜索引擎的ip訪問

map $limited $limit {
1 $binary_remote_addr;
0 "";
}

3.設置limit_req_zone和limit_req

limit_req_zone $limit zone=foo:1m rate=10r/m;

limit_req zone=foo burst=5;

最后我們使用ab壓php-fpm的方式,對上面的方法效果實際測試下

例1:限制只允許一分鐘內只允許一個ip訪問60次配置,也就是平均每秒1次

首先我們準備一個php腳本放在根目錄下$document_root

test.php

<?
for( $i=0; $i < 1000; $i++)
echo 'Hello World';
?>

nginx配置增加limit_req_zone 和 limit_req

http{
  ...
  limit_req_zone $binary_remote_addr zone=allips:10m rate=60r/m;
  ...
  server{
    ...
    location {
      ...
      limit_req zone=allips;
      ...
    }
    ...
  }
  ...
}
# ab -n 5 -c 1 http://blog.rekfan.com/test.php
127.0.0.1- - [22/Dec/2012:06:27:06 +0000] "GET /test.php HTTP/1.0" 200 11000 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:06:27:06 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:06:27:07 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:06:27:07 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:06:27:07 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"

未設置brust和nodelay可以看到該配置只允許每秒訪問1次,超出的請求返回503錯誤

http{
  ...
  limit_req_zone $binary_remote_addr zone=allips:10m rate=60r/m;
  ...
  server{
    ...
    location {
      ...
      limit_req zone=allips burst=1 nodelay;
      ...
    }
    ...
  }
  ...
}

# ab -n 5 -c 1 http://blog.rekfan.com/test.php
127.0.0.1- - [22/Dec/2012:07:01:00 +0000] "GET /test.php HTTP/1.0" 200 11000 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:07:01:00 +0000] "GET /test.php HTTP/1.0" 200 11000 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:07:01:01 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:07:01:01 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"
127.0.0.1 - - [22/Dec/2012:07:01:01 +0000] "GET /test.php HTTP/1.0" 503 537 "-" "Rekfan_Server/1.2.6"

設置brust=1和nodelay后允許第1秒處理兩個請求。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:鄭州 石嘴山 拉薩 汕頭 玉林 晉城 三明 開封

巨人網絡通訊聲明:本文標題《基于Nginx實現限制某IP短時間訪問次數》,本文關鍵詞  基于,Nginx,實現,限制,某,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于Nginx實現限制某IP短時間訪問次數》相關的同類信息!
  • 本頁收集關于基于Nginx實現限制某IP短時間訪問次數的相關信息資訊供網民參考!
  • 推薦文章
    一本高清在线| 成人免费观看男女羞羞视频| 青青青草影院| 国产精品免费久久| 黄色短视屏| 亚洲第一色在线| 日韩免费在线视频| 精品视频在线观看免费| 日本免费乱人伦在线观看 | 韩国毛片免费大片| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 天堂网中文字幕| 国产美女在线一区二区三区| 久久久久久久男人的天堂| 亚洲天堂一区二区三区四区| 黄色免费三级| 台湾毛片| 天天色成人| 精品久久久久久中文字幕2017| 成人免费网站久久久| 国产精品1024永久免费视频| 日韩在线观看视频黄| 国产网站在线| 青青青草影院| 精品在线视频播放| 亚洲精品久久久中文字| 国产综合91天堂亚洲国产| 黄色福利片| 国产高清在线精品一区二区 | 韩国毛片免费| 在线观看导航| 久久久久久久久综合影视网| 久久精品大片| 亚洲精品影院久久久久久| 四虎久久影院| 九九久久99| 欧美激情影院| 久久久久久久男人的天堂| 青青久久精品| 午夜久久网| 欧美一级视| 久久99爰这里有精品国产| 亚洲不卡一区二区三区在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品毛片视频| 成人免费观看男女羞羞视频| 欧美1区| 日韩avdvd| 精品久久久久久中文字幕2017| 青青久久精品| 久久国产一久久高清| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产91视频网| 国产精品自拍一区| 色综合久久久久综合体桃花网| 四虎影视久久久免费| 国产一区二区精品尤物| 日日爽天天| 高清一级毛片一本到免费观看| 国产视频一区二区在线播放| 日韩在线观看免费完整版视频| 精品国产香蕉在线播出| 亚洲精品影院一区二区| 国产一区精品| 九九干| 999久久狠狠免费精品| 日韩一级精品视频在线观看| 黄视频网站在线观看| 国产a网| 精品国产一区二区三区免费| 国产91精品一区| 日韩在线观看视频黄| 在线观看成人网 | 精品国产三级a| 青青青草影院 | 欧美大片一区| 韩国毛片免费大片| 日韩免费在线视频| 精品视频在线观看视频免费视频 | 欧美另类videosbestsex视频 | 亚洲精品影院一区二区| 精品视频在线观看视频免费视频| 国产网站在线| 精品视频在线观看免费| 国产亚洲精品aaa大片| 精品国产一区二区三区精东影业| 国产网站在线| 国产精品自拍一区| 精品在线视频播放| 亚洲天堂免费| 精品视频在线观看一区二区三区| 成人高清护士在线播放| 午夜在线影院| 成人a大片高清在线观看| 韩国三级香港三级日本三级| 91麻豆国产福利精品| 久草免费在线色站| 国产伦精品一区三区视频| 天天做日日干| 毛片的网站| 一级毛片视频在线观看| 午夜欧美成人香蕉剧场| 91麻豆国产级在线| 国产高清视频免费| 国产一区二区精品在线观看| 青草国产在线观看| 欧美激情影院| 99久久精品国产国产毛片| 国产91视频网| 欧美电影免费| 国产精品免费久久| 九九久久国产精品| 免费毛片播放| 欧美a级片视频| 在线观看成人网 | 人人干人人草| 韩国毛片| 国产一级强片在线观看| 你懂的在线观看视频| 九九精品久久久久久久久| 人人干人人草| 91麻豆精品国产片在线观看| 国产麻豆精品高清在线播放| 999久久66久6只有精品| 国产精品自拍在线观看| 成人免费一级毛片在线播放视频| 高清一级片| 台湾美女古装一级毛片| 99久久精品国产国产毛片| 国产网站免费视频| 毛片的网站| 国产麻豆精品免费密入口| 四虎久久精品国产| 日韩免费在线观看视频| 日韩在线观看视频黄| 日韩免费在线视频| 久久国产精品只做精品| 欧美1卡一卡二卡三新区| 日韩男人天堂| 国产91视频网| 成人av在线播放| 99久久网站| 成人a大片高清在线观看| 999久久狠狠免费精品| 高清一级做a爱过程不卡视频| 日韩一级黄色片| 日韩字幕在线| 一级毛片视频在线观看| 欧美激情在线精品video| 91麻豆精品国产综合久久久| 成人av在线播放| 亚欧乱色一区二区三区| 精品国产一区二区三区久久久狼 | 青青青草影院 | 韩国毛片免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | a级黄色毛片免费播放视频| 色综合久久天天综合绕观看| 国产网站免费在线观看| 久久国产一久久高清| 精品久久久久久中文字幕2017| 在线观看成人网 | 九九国产| 韩国三级视频网站| 91麻豆精品国产高清在线| 成人a大片高清在线观看| 精品国产亚洲人成在线| 午夜精品国产自在现线拍| 黄色短视屏| 久久国产精品自由自在| 国产91精品一区| 九九精品久久| 一本高清在线| 青青青草影院 | 国产精品自拍在线观看| 在线观看成人网 | 国产a视频| 尤物视频网站在线| 久久久成人网| 精品视频一区二区三区免费| 亚洲wwwwww| 成人在免费观看视频国产| 国产视频一区二区三区四区| 欧美1卡一卡二卡三新区| 日日爽天天| 欧美另类videosbestsex视频| 欧美激情伊人| 91麻豆精品国产自产在线| 韩国三级视频网站| 日本在线不卡免费视频一区| 黄视频网站免费看| 国产麻豆精品免费视频| 午夜在线观看视频免费 成人| 九九精品久久| 精品视频在线观看一区二区| 日韩在线观看网站| 欧美激情一区二区三区视频 | 国产极品精频在线观看| 成人a级高清视频在线观看| 免费的黄色小视频|