> 운영 및 유지보수 > 엔진스 > Nginx 긴급 구매 현재 제한을 구성하는 방법

Nginx 긴급 구매 현재 제한을 구성하는 방법

王林
풀어 주다: 2023-05-15 22:58:10
앞으로
1323명이 탐색했습니다.

코드는 다음과 같습니다.

  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 모듈도 사용할 수 있습니다.

특히 일부 컨설팅 웹사이트가 크롤러의 대상이 되는 경우, 크롤러에 의해 서버가 종료될 수 있습니다(작은 웹사이트의 경우)

그러려면 어떻게 해야 할까요?

#全局配置
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;   #设置变量,进入这里的就进行限速
}
로그인 후 복사

위 내용은 Nginx 긴급 구매 현재 제한을 구성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿