一、全局限流

 在http节点中添加

 # 创建限流规则
    limit_req_zone $binary_remote_addr zone=addr:10m rate=1r/s;# 客户端进行限流
    # limit_req_zone $server_name zone=addr:10m rate=1r/s; # 服务端进行限流
    server {
        # 监听端口默认是80
        listen 80;

        # 服务器ip或域名
        server_name 192.168.140.130;
         location / {
             limit_req zone=addr burst=1 nodelay;
             proxy_pass http://xiaohemiao;

         }
    }

    upstream xiaohemiao {


        server 192.168.140.130:7777; # 应用端口7777
        server 192.168.140.130:8888; # 应用端口8888
    }
  • $binary_remote_addr 针对客户端ip限流;
  • $server_name 针对服务端进行限流
  • zone=ip_limit:10m 限流规则名称为ip_limit,允许使用10MB的内存空间来记录ip对应的限流状态;
  • rate=1r/s 限流速度为每秒1次请求
  • burst为允许缓存的速率数量进行排队
  • nodelay为不需要等待排队

二、自定义限流

比如只对登录进行限流,假设登录接口名为login

location = /login {
             limit_req zone=addr burst=1 nodelay;
             proxy_pass http://xiaohemiao;

         }

 

在配置中需要注意的一点是location匹配规则和优先级

= 开头表示精确匹配

^~ 开头表示url以某个常规字符串开头,不是正则匹配

~ 表示区分大小写的匹配

~* 开头表示不区分大小写的正则匹配

/ 通配匹配,如果没有其他匹配,任何请求都会匹配到

 

作者:|SportSky|,原文链接: https://www.cnblogs.com/sportsky/p/16293870.html

文章推荐

Springboot2.x整合ElasticSearch7.x实战(一

boost::bind 不能处理函数重载 (error: no matching functio...

单词搜索问题

MySQL的Explain总结

一次生产环境的docker MySQL故障

基于SqlSugar的开发框架循序渐进介绍(5)-- 在服务层使用接...

【原创】Selenium获取请求头、响应头

Tomcat改jar

超详细:如何在windous系统下使用wsl虚拟机安装Ubuntu

JavaScript 运行堆栈与闭包

一文带你了解 「图数据库」Nebula 的存储设计和思考

人最重要的能力是什么?