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

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;
        }
    }
}
posted @   剑心空明  阅读(49)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示