52AV手機A片王|52AV.one

 找回密碼
 立即註冊
查看: 1372|回復: 0

[nginx|php-fpm] nginx限制某個IP同一時間的連線數及頻寬

[複製鏈接]
發表於 2016-3-30 23:00:43 | 顯示全部樓層 |閱讀模式
tid=34035&對於負載量比較高的伺服器,可以設定每一位使用者可使用的資源上限,例如同時間最大連線數、連線頻率(每秒或每分鐘連線次數)以及下載速度。$ ~/ T. H" M9 R

0 p2 ?* v9 h5 Q( w& T4 e1 ]同時間最大連線數若要限制同時間最大連線數,首先要使用 limit_conn_zone 定義一個 key 與 zone 參數:
  1. limit_conn_zone $binary_remote_addr zone=addr:10m;
複製代碼
說明:3 c" p0 Y! w8 |* q" L) K4 k3 u/ P
定義一個名為 addr 的 zone,空間大小是 10MB,worker 行程會使用這個 zone 所配置的共享記憶體空間來儲存 key 的計數值。我們使用 $binary_remote_addr 來作為判斷來源 IP 的依據(key),會使用這個二進位的變數來作為 key 是因為它跟一般的字串比起來,會比較省空間,如果 zone 所配置的共享記憶體空間用完了,那伺服器就會回傳 503(Service Temporarily Unavailable)的錯誤訊息。5 N/ d8 f- V5 m+ |: ~, i

; H* ]/ r6 j$ F  ~* @: }8 T* M" t

$ M" u$ ^& h5 m/ h  @( e. u- E  Q" Z接著使用 limit_conn 指定一個 IP 同時間可以允許的最大連線數:
  p( ?! d1 Y6 Q( f5 T7 U- T
  1. location /download/ {
      K/ o/ @  q3 V: t" K2 z) b
  2.   limit_conn addr 5;: Z; {& p, q  @" Z6 l4 P  k
  3. }
複製代碼
  c) F8 u3 h2 N( F% I
9 e& i1 }1 o; N9 W7 I3 \4 t
或是在 server 段針對Domain而不針對上例的目錄來限制連線

6 Q# D* W5 J' {/ q, y' d2 ]
  1. .
    ) {+ a. Z/ n% z5 G1 @
  2. .
    - M' \1 v* W1 m( n! _, H( F; z6 o
  3. .6 o' J8 h8 ]3 E2 @( c7 O" N1 O
  4. server {% r6 x" l9 n: b; ^% D
  5.   .( i2 _+ e# t; S1 z- X7 a$ M. X! C, v
  6.   .! F+ E( Q7 f4 W: b- v% k' s
  7.   limit_conn addr 5;( ~8 I) _7 F! s, E
  8.   .
    ; ], t6 i! a( `. _: n1 ?$ z
  9.   .
    8 F7 G& a7 ]* Q8 r
  10. }
複製代碼

9 d6 a: Z. y. l) T+ ^9 c* n
8 l+ r3 F' T5 G& O* ~: J
連線頻率(每個IP單位時間的連線數)
! V( R6 k3 c. H* o$ H0 K, {
4 |0 V# q4 _& X& w. I7 X$ _

' N) [" }8 [. Q+ l若要限制連線頻率,首先也是一樣要用 limit_req_zone 定義 key 與 zone 參數:
& I5 G: E) S/ V- Q
  1. limit_req_zone $binary_remote_addr zone=one:10m rate=1r/s;
複製代碼
& q7 S' }# Q9 ~0 o
除了定義 zone 的名稱與大小之外,還加上了一個 rate 指定連線頻率的上限,單位可以使用每秒的連線次數(r/s)或是每分鐘的連線次數(r/m),r是request
例如若要指定每分鐘不可超過 30 次連線,則設定為 30r/m。
, `) q0 h8 ~1 Y, ^+ p4 ^3 ?
6 n1 r* x3 Z, r% L

: N" c0 {9 i9 S0 u8 h然後在需要限制連線頻率的地方加上 limit_req 的設定:

$ S& y5 A8 |' D% W5 Z8 b4 M4 E
  1. location /download/ {5 y* Z2 v2 s' S* P4 A6 T
  2.   limit_req zone=one burst=5;
    / M: H6 W; j5 X8 l$ i( N3 `
  3. }
複製代碼
1 \( {' E0 L/ Z4 E, Q  y/ V' J
或是在 server 段針對Domain而不針對上例的目錄來限制頻率
) J7 h1 e1 y% k6 C1 G
  1. .
    # h: o8 Z! [- b3 M! _1 ^, b0 @
  2. .
    4 v' Y( z7 r; [: m$ t; ~
  3. .$ P( [4 k( E7 C4 p3 `- I
  4. server {
    8 n+ h4 v% G* S* ?, P/ D% W
  5.   ./ e  r( H% q- z/ M& s
  6.   ." p% Y. s7 H" S9 l
  7.   <span style="font-family: Tahoma;">limit_req zone=one burst=5;</span>
    5 U7 n' d. p5 T  V) d' j' a7 Y, }
  8.   .- T% p  \! I1 k" c4 w! C' R
  9.   .
    / V- F0 P" f9 }" V, r6 m
  10. }
複製代碼

% a4 R- Z5 ~& X9 g! w
0 M3 z- U0 Z9 ~7 u* P0 ^  A/ P4 R
結論:

; w( I# j6 C4 Z5 X4 A+ E( C  y/ n) h! W( y
對於以上的設定可以有效防止駭客攻擊以及那些有心之徒試圖消耗你無畏的頻寬
8 j. o& _2 t; C, L0 l
* K$ Z: B! @+ b$ t! H
其他請參閱 :( `: A2 G4 h, w; `, K8 ~- N* V
https://blog.gtwang.org/linux/ng ... address-tutorial/2/
& V! Y5 e4 d0 v" A3 d' whttp://www.nginx.cn/446.html
6 x, _- y' X6 \5 g8 \
* k* \6 C$ Q. o/ e& b
回復

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即註冊

本版積分規則



中文酷站排行榜

本區塊內容依據『電腦網路內容分級處理辦法』為限制級網站,限定年滿18歲以上或達當地國家法定年齡人士方可進入,且願接受本站各項條款,未滿18歲 謝絕進入瀏覽。為防範未滿18歲之未成年網友瀏覽網路上限制級內容的圖文資訊,建議您可進行網路內容分級組織ICRA分級服務的安裝與設定。 (為還給愛護 本站的網友一個純淨的論壇環境,本站設有管理員)

QQ|小黑屋|手機板| 52AV手機A片王

GMT+8, 2025-12-6 19:27 , Processed in 0.056516 second(s), 16 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回復 返回頂部 返回列表