今天分享一个之前做的redis限流包,最近加班比较忙,先把git地址传上来,后续再详细介绍逻辑,有兴趣的小伙伴可以clone下来自己试试。
redis限流maven工程github地址:
https://github.com/oldwang666666/redis-limit-module
redis限流包引用示例代码github地址:
https://github.com/oldwang666666/springboot-redis-limit-demo
操作步骤
1、clone redis限流maven工程,执行install打出jar包
2、clone redis限流包引用示例工程,修改redis地址
3、启动 SpringbootRedisLimitDemoApplication
4、调用http://127.0.0.1:8080/test/getLimit 或 http://127.0.0.1:8080/test/getControllerLimit 查看demo的限流过程。
1)、正常执行如下图
2)、多次操作限流返回如下图、目前限流以秒为单位
redis限流maven包redis-limit-module结构
1、我们先看下限流方法类实现 RedisCurrentLimit.java,目前我只自测了单机模式,集群模式等有时间再进行测试和调整
package com.wang.limit.fuse;
import com.wang.limit.intercept.Message;
import com.wang.limit.util.ScriptUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.data.redis.connection.RedisClusterConnection;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisCluster;
import redis.clients.jedis.JedisPool;
import java.io.IOException;
import java.util.Collections;
/**
* redis限流实现类
* Description:
* Created by longzhang.wang
* Date: 2019-09-29
*/
public class RedisCurrentLimit {
private static final Logger logger= LoggerFactory.getLogger(RedisCurrentLimit.class);
/**
* 默认为单机模式
*/
private boo