例子使用Guava的限流框架
GatewayRateLimitFilter :
/** * 限流过滤器 */ public class GatewayRateLimitFilter extends OncePerRequestFilter { private RateLimiter rateLimiter = RateLimiter.create(1); @Override protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException { System.err.println("0 rate limit "); if(rateLimiter.tryAcquire()){ filterChain.doFilter(request,response); }else { response.setStatus(HttpStatus.TOO_MANY_REQUESTS.value()); response.setContentType("application/json"); response.getWriter().write("{\"error\":\"too many request\"}"); response.getWriter().flush(); return; } } }
限流过滤器,加载SpringSecurity过滤器链的第一个过滤器前
完成。
代码:https://github.com/lhy1234/springcloud-security/tree/chapt-6-5-ratelimit
第六章总结
欢迎关注个人公众号一起交流学习: