等不见天亮等时光

等不见天亮等时光
夜晚的堤岸,晃动着沉默的黑水。此岸草木枯竭,彼岸人烟繁盛。
  1. 首页
  2. 编码总结
  3. java
  4. 正文

分布式限流组件lua

2021年3月25日 20点热度 0人点赞 0条评论
  • 从Maven依赖开始🛠

    <dependency>
    <groupId>com.github.sunywdev</groupId>
    <artifactId>routelimit</artifactId>
    <version>1.0.1</version>
    </dependency>
  • 全局限流

    route:
    #每秒产生的令牌数量,配置使用时为:一个请求URL的匀速并发量 例:http://127.0.0.1:8081/send 接口最大并发魏2000/匀速为1500
    #分布式环境下使用时,为多个ip地址加请求URI的限制
    replenishrate: 1500
    #桶内令牌容量:一个请求URL的最大并发量
    burstcapacity: 2000
    #每次获取令牌数量
    acquiredquantity: 1
    #发送人邮箱
    formmailaddress:
    #服务异常通知人邮箱,多个使用 , 分隔开
    sendmailaddress:
    #是否开启日志链路追踪,默认不开启
    startlog: true
  • 基于接口配置限流,使用@RouteLimiter注解

    /**
    * repleniShrate :每秒产生的令牌数量;
    * burstCapacity:桶内令牌容量;
    * acquiredQuantity:每次获取令牌数量(一般配置为1);
    *
    * @return
    */
    @GetMapping("/logerror")
    @RouteLimiter(repleniShrate = 1, burstCapacity = 2, acquiredQuantity = 1)
    @Log(name = "限流测试")
    public Map<String, Object> logError() {
    Map<String, Object> respMap = new HashMap<>();
    respMap.put("code", "200");
    respMap.put("msg", "success");
    return respMap;
    }
  • 日志链路记录使用@Log注解,并初始化Db文件,数据库使用MySql数据库

-- 正常情况
在这里插入图片描述
在这里插入图片描述

-- 触发限流
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 欢迎往Github提交issues,有帮助的可以Fork或者点个⭐
  • 源码地址:
    -- github
    -- gitee
本作品采用 知识共享署名 4.0 国际许可协议 进行许可
标签: 暂无
最后更新:2021年4月8日

sunyw

这个人很懒,什么都没留下

点赞
下一篇 >

文章评论

取消回复
分类
最新 热点 随机
最新 热点 随机
ArrayBlockingQueue消息队列 SpringBoot整合ActiveMQ SpringBoot集成Dubbo示例 Linux环境下zookeeper的配置和安装以及dubbo-admin的安装和配置 springcloud初体验环境搭建 截取从指定位置开始字符串长度按照字节
分布式限流组件luajava自定义注解进行出参入参日志打印基于zookeeper+curator的分布式锁代码实现redis分布式锁基于springdataredis基于redisson的分布式锁使用Liunx环境下配置mysql数据库主从复制
Memcached安装及集成springboot java自定义注解进行出参入参日志打印 Linux环境下zookeeper的配置和安装以及dubbo-admin的安装和配置 SpringBoot集成Dubbo示例 Liunx环境下配置mysql数据库主从复制 截取从指定位置开始字符串长度按照字节
最近评论

COPYRIGHT © 2021 等不见天亮等时光. ALL RIGHTS RESERVED.

THEME KRATOS MADE BY VTROIS

豫ICP备19043985号