Redisson实现限流

1. 引入Redisson

参考: 这篇文章即可。

2. 使用RedissonClinet实现

代码如下:

java 复制代码
import org.redisson.api.RRateLimiter;
import org.redisson.api.RateIntervalUnit;
import org.redisson.api.RateType;
import org.redisson.api.RedissonClient;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;

/**
 * redis 限流管理器
 * @author xxx
 * @version 1.0
 * @date xxx
 */

@Service
public class RedisLimiterManager {
    @Resource
    private RedissonClient redissonClient;

    /**
     * 限流操作
     *
     * @param key 限流key
     * @param limit 指定时间内允许的请求数
     * @param ttl 指定时间
     * @param ttl message 限流的提示信息
     */
    public void doRateLimit(String key, int limit, int ttl, String message) {
        // 创建限流器
        RRateLimiter rateLimiter = redissonClient.getRateLimiter(key);
        rateLimiter.trySetRate(RateType.OVERALL, limit,
                ttl, RateIntervalUnit.SECONDS);
        // 获取令牌
        boolean result = rateLimiter.tryAcquire(1);
        if (!result){
            throw new RuntimeException(message);
        }
    }
}

3. 使用用限流

如下:

java 复制代码
// 限流, 一天只能访问10次, 被限流会抛异常
String limitKey = "prefix:" + loginUser.getId();
int limitTime = 24 * 60 * 60;
redisLimiterManager.doRateLimit(limitKey, 10, limitTime, "今天的请求次数为0");
相关推荐
加油,旭杏1 小时前
【Redis】数据结构和内部编码
数据库·redis·缓存
佳腾_2 小时前
【高性能缓存Redis_中间件】三、redis 精通:性能优化与生产实践
redis·缓存·云原生·中间件·云计算
Huazie2 小时前
flea-cache使用之Redis哨兵模式接入
java·redis·开源
想念泡凤爪的味道2 小时前
基于Redission实现分布式调度任务选主
redis·spring cloud·springboot
Json20113153 小时前
Redis 在处理并发请求时,如何保证高效性和数据一致性
redis
blueboySalvat4 小时前
Redis分布式锁的两种实现方式(Redis+定时任务/Redisson)
redis
hac13225 小时前
redis大key排查指南
数据库·redis
风象南6 小时前
Redis管道技术:提升Java应用中的Redis操作性能
redis·后端
餘yuqn11 小时前
redis搭配布隆过滤器避免缓存穿透
redis
不剪发的Tony老师13 小时前
SQLite + Redis = Redka
数据库·redis·sqlite