您好,登錄后才能下訂單哦!
因業務需求經常會有搶購業務,因此需要在負載均衡前端進行限流錯誤。本文同樣也適用于防止CC.
limit_req_zone $server_name zone=sname:10m rate=1r/s; #限制服務器每秒只能有一次訪問成功 #limit_req_zone $binary_remote_addr zone=one:3m rate=1r/s; #限制IP,每秒只能訪問一次 #limit_req_zone $binary_remote_addr $uri zone=two:3m rate=1r/s; #限制IP和路徑不帶參數, #limit_req_zone $binary_remote_addr $request_uri zone=thre:3m rate=1r/s; #限制IP和帶參數的路徑 server { listen 80; server_name www.abc.com; location / { include host/proxy.cnf; proxy_pass http://backend; } location /api/createOrder { limit_req zone=sname; #不帶突發,只能有一次正常請求 limit_req_status 503; #設置返回的狀態碼是503 #limit_req zone=sname burst=5 nodelay; #最大并發是5,并且實時處理 include host/proxy.cnf; proxy_pass http://backend; error_page 503 =200 /50x.html; #這里很重要,可以將錯誤的狀態碼503,返回結果的時候是200 } location = /50x.html { if ($http_user_agent ~* "mobile|android|iPhone|iphone|ios|iOS"){ #default_type application/json; return 200 '{"msg": "活動過于火爆,請稍后重試!","data": {},"code": -1}'; #設置移動端返回錯誤的信息顯示 } root html; #如果是PC端返回一個HTML頁面 } }
重點: 正常情況下,如果設置了限流,返回是503的狀態碼,這對于移動端來說即便是你返回JSON數據但是客戶端時不認的,這個時候巧妙的通過 error_page 403 =200 /50x.html;將狀態碼設置為200
以上只是使用了ngx_limit_req_module,同時也可以使用ngx_limit_conn_module模塊。
以上參考: https://gist.github.com/simlegate/75b18359316cc33d8e20
特別是一些咨詢類網站如果備爬蟲盯上,服務器可能會被爬蟲給干死(小網站就是這樣)
那么怎么辦呢,我們可以使用變量去做
#全局配置 limit_req_zone $spider zone=spider:60m rate=200r/m; #限制爬蟲每分鐘只能跑200次 #某個server中 limit_req zone=spider burst=5 nodelay; if ($http_user_agent ~* “spider|bot”) { set $spider $http_user_agent; #設置變量,進入這里的就進行限速 }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。