0
点赞
收藏
分享

微信扫一扫

SpringCloud 网关限流方式二:通过Guava实现限流

早安地球 2022-04-03 阅读 65
微服务

Google的Guava工具包中就提供了一个限流工具类——RateLimiter,本文也是通过使用该工具类来实现限流功能。RateLimiter是基于“令牌通算法”来实现限流的。

令牌桶: 1.令牌生成器以固定速率向令牌桶放令牌,如果桶满了就丢弃 2.调用者去令牌桶拿令牌,拿不到就拒接访问。

限流的本质有两点: 1.生成令牌 2.抢令牌

step1: pom.xml

<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>31.1-jre</version>
</dependency>

step2. 代码,在网关中增加限流过滤器,每秒最多支持100并发,超过后拒绝请求

@Component
public class LimitFilter extends ZuulFilter {
    //以固定的速度每秒产生10个令牌,
    private static final RateLimiter RATE_LIMITER = RateLimiter.create(10);

    @Override
    public String filterType() {
        return FilterConstants.PRE_TYPE;
    }

    @Override
    public int filterOrder() {
        return -100;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() throws ZuulException {
        System.out.println("过滤器--1");
        RequestContext currentContext = RequestContext.getCurrentContext();
        if (RATE_LIMITER.tryAcquire()) {
            return null;
        } else {
            currentContext.set("limit", false);//控制过滤器--2   
            currentContext.setResponseStatusCode(HttpStatus.TOO_MANY_REQUESTS.value());
        }
        return null;
    }
}
举报

相关推荐

0 条评论