| | |
| | | @Before("@annotation(rateLimiter)")
|
| | | public void doBefore(JoinPoint point, RateLimiter rateLimiter) throws Throwable
|
| | | {
|
| | | String key = rateLimiter.key();
|
| | | int time = rateLimiter.time();
|
| | | int count = rateLimiter.count();
|
| | |
|
| | |
| | | Long number = redisTemplate.execute(limitScript, keys, count, time);
|
| | | if (StringUtils.isNull(number) || number.intValue() > count)
|
| | | {
|
| | | throw new ServiceException("访问过于频繁,请稍后再试");
|
| | | throw new ServiceException("访问过于频繁,请稍候再试");
|
| | | }
|
| | | log.info("限制请求'{}',当前请求'{}',缓存key'{}'", count, number.intValue(), key);
|
| | | log.info("限制请求'{}',当前请求'{}',缓存key'{}'", count, number.intValue(), combineKey);
|
| | | }
|
| | | catch (ServiceException e)
|
| | | {
|
| | |
| | | }
|
| | | catch (Exception e)
|
| | | {
|
| | | throw new RuntimeException("服务器限流异常,请稍后再试");
|
| | | throw new RuntimeException("服务器限流异常,请稍候再试");
|
| | | }
|
| | | }
|
| | |
|