博客
关于我
Springboot 整合 redis实现令牌桶限流
阅读量:174 次
发布时间:2019-02-28

本文共 771 字,大约阅读时间需要 2 分钟。

1.引入redis依赖

org.springframework.boot
spring‐boot‐starter‐data‐redis‐reactive
2.1.3.RELEASE

2.定义一个限流的key

@Bean    public KeyResolver ipKeyResolver() {           return new KeyResolver() {               @Override            public Mono
resolve(ServerWebExchange exchange) { returnMono.just(exchange.getRequest().getRemoteAddress().getHostName()); } }; }

3.在application.yml中设置redis和令牌桶生成令牌速率

‐ name: RequestRateLimiter #请求数限流 名字不能随便写          args:            key‐resolver: "#{@ipKeyResolver}"            redis‐rate‐limiter.replenishRate: 1 #令牌桶每秒填充平均速率            redis‐rate‐limiter.burstCapacity: 1 #令牌桶总容量

4.配置redis

redis:    host: 192.168.200.128    port: 6379

转载地址:http://gitj.baihongyu.com/

你可能感兴趣的文章
Nat、端口映射、内网穿透有什么区别?
查看>>
nat打洞原理和实现
查看>>
NAT技术
查看>>
NAT模式下虚拟机centOs和主机ping不通解决方法
查看>>
NAT的两种模式SNAT和DNAT,到底有啥区别?
查看>>
NAT网络地址转换配置实战
查看>>
NAT网络地址转换配置详解
查看>>
Navicat for MySQL 命令列 执行SQL语句 历史日志
查看>>
Navicat for MySQL 查看BLOB字段内容
查看>>
Navicat for MySQL(Ubuntu)过期解决方法
查看>>
Navicat Premium 12 卸载和注册表的删除
查看>>
Navicat 导入sql文件
查看>>
navicat 添加外键1215错误
查看>>
navicat 系列软件一点击菜单栏就闪退
查看>>
Navicat 设置时间默认值(当前最新时间)
查看>>
navicat 连接远程mysql
查看>>
navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
查看>>
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>