基于redis的分布式锁实现,使用redistemplate操作

时间:2025-03-21 22:49:39

redis常用场景之分布式锁

Springboot下集成redis请参考:/m0_37179470/article/details/81219424
可以用于验证前端的重复请求,可以通过redis进行过滤:每次请求将request Ip、参数、接口等hash作为key存储redis(幂等性请求),设置多长时间有效期,然后下次请求过来的时候先在redis中检索有没有这个key,进而验证是不是一定时间内过来的重复提交秒杀系统,基于redis是单线程特征,防止出现数据库“爆破”。

这里用于调度任务时避免多次对数据库操作。

package ;

import ;
import ;
import ;

import ;

/**
 * @author lzz
 * @description:
 * @date 2018/7/31 14:05
 */
@Service
public class RedisLockService {

    @Autowired
    private StringRedisTemplate redisTemplate;

    private final String LOCKVALUE = "lockvalue";

    private boolean locked = false;

    public synchronized boolean lock(String lockKey){
        /*该方法会在没有key时,设置key;存在key时返回false;因此可以通过该方法及设置key的有效期,判断是否有其它线程持有锁*/
        Boolean success = ().setIfAbsent(lockKey,LOCKVALUE);
        if(success != null && success){
            (lockKey,3,);
            locked = true;
        }else{
            locked = false;
        }
        return locked;
    }
}

相关文章