Redis分布式锁代码实现(Java)

在这里插入图片描述

public class RedisLock {

    public static Boolean getLock(RedisTemplate redisTemplate, String key, String value, long timeout) {
        Boolean lock = redisTemplate.opsForValue().setIfAbsent(key,value,timeout,TimeUnit.SECONDS); //获取锁
        return lock;
    }
    
    public static void closeLock(RedisTemplate redisTemplate,String key, String value) {
        while (true) {
            redisTemplate.watch(key);//保证原子性
            String revalue=String.valueOf(redisTemplate.opsForValue().get(key));
            if (value.equalsIgnoreCase(revalue)) {//判断是否是当前锁
                redisTemplate.setEnableTransactionSupport(true);
                redisTemplate.multi();
                redisTemplate.delete(key);
                List<Object> rlist = redisTemplate.exec();
                if (rlist == null) {
                    continue;
                }
            }
            redisTemplate.unwatch();
            break;
        }
    }
}
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐