博客
关于我
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/

你可能感兴趣的文章
navicat怎么导出和导入数据表
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
navigationController
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
NBear简介与使用图解
查看>>
Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
查看>>
Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
查看>>
NCNN中的模型量化解决方案:源码阅读和原理解析
查看>>
NCNN源码学习(1):Mat详解
查看>>