RedLock使用教程 redis锁

RedLock使用教程 redis锁,第1张

RedLock使用教程 redis锁 项目基于springboot

首先是pom文件

        
            org.redisson
            redisson-spring-boot-starter
            3.16.4
        

官方推荐使用redisson

接上代码
注册

    @Autowired
    private RedissonClient redissonClient;

获取锁

RLock lock = redissonClient.getLock(Redismeta.LOCK_KEY);
        boolean getLock = false;
        try {
            getLock = lock.tryLock(2, 120, TimeUnit.SECONDS);
            if (getLock) {
                taskSync();
            } else {
                error("上一次还未执行完");
            }
            if (getLock && lock.isLocked()) {
                lock.unlock();
            }
        } catch (InterruptedException interruptedException) {
            log.error("分布式锁加锁异常", interruptedException);
            Thread.currentThread().interrupt();
        } finally {
            if (getLock && lock.isLocked()) {
                lock.unlock();
            }
        }

解释说明
测试中发现使用
lock.lock();确实可以锁住不会并发执行
但是第一个lock执行完之后第二个又开始执行,并不能达到仅执行一次的目的,所以此处使用tryLock

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5638390.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存