简单实现一个接口限流
一,背景
在项目中,通常会需要对一些关键资源的调用做一些限制,以防止系统被拖垮。下面基于Springboot 3.x来简单实现一个限流。
二,实现
1, 引入resilience4j
<dependency><groupId>io.github.resilience4j</groupId><artifactId>resilience4j-spring-boot3</artifactId><version>2.3.0</version>
</dependency>
2,添加配置
# 在项目的配置文件里添加一下配置 resilience4j:ratelimiter:instances:# 实例名,对应服务里@RateLimiter注解里的namechatRateLimit:# 在时间窗口里最多允许多少个请求limit-for-period: 20# 时间窗口,单位秒limit-refresh-period: 10s# 在指定的超时时间内,如果获取令牌成功,则返回true,否则返回falsetimeout-duration: 1s
3, 添加RateLimiter
这里定义了RateLimiter, 里面的name要和配置文件里的一致, 同时定义了fallback方法,当被限流的时候会自动调用fallback方法。 这里限流器方法里的逻辑很简单,实际场景下可能会比较复杂,一些调用后端重要资源的逻辑会放在这里面。
4,测试
当频繁调用外层接口时, 比如10秒钟超过20次调用,就会降级。
完成限流!
三,总结
通过resilience4j 简单实现限流,特别灵活