温馨提示×

如何用Nginx限制访问频率

小樊
50
2025-11-28 04:41:04
栏目: 编程语言

使用Nginx限制访问频率可以通过配置ngx_http_limit_req_module模块来实现。这个模块允许你设置请求速率限制,以防止恶意用户或爬虫对服务器造成过大压力。以下是一个基本的配置示例:

  1. 安装Nginx(如果尚未安装):

    sudo apt update
    sudo apt install nginx
    
  2. 编辑Nginx配置文件: 通常,Nginx的主配置文件位于/etc/nginx/nginx.conf,但你也可以在特定的虚拟主机配置文件中进行设置。

  3. 配置访问频率限制: 在Nginx配置文件中,找到或添加一个httpserverlocation块,并添加以下配置:

    http {
        # 定义一个共享内存区域来存储请求计数器
        limit_req_zone $binary_remote_addr zone=mylimit:10m rate=1r/s;
    
        server {
            listen 80;
            server_name example.com;
    
            location / {
                # 应用访问频率限制
                limit_req zone=mylimit burst=5 nodelay;
    
                # 其他配置...
                root /var/www/html;
                index index.html index.htm;
            }
        }
    }
    

    解释:

    • limit_req_zone $binary_remote_addr zone=mylimit:10m rate=1r/s;
      • $binary_remote_addr:使用客户端的IP地址作为键。
      • zone=mylimit:10m:定义一个名为mylimit的共享内存区域,大小为10MB。
      • rate=1r/s:每秒允许的最大请求数为1。
    • limit_req zone=mylimit burst=5 nodelay;
      • zone=mylimit:使用之前定义的共享内存区域。
      • burst=5:允许短时间内的突发请求最多为5个。
      • nodelay:不对突发请求进行延迟处理,立即响应。
  4. 重新加载Nginx配置: 保存配置文件并重新加载Nginx以应用更改:

    sudo nginx -s reload
    

通过以上步骤,你已经成功配置了Nginx来限制访问频率。你可以根据需要调整rateburst参数,以适应你的具体需求。

0