redisson分布式锁

一、分布式锁

java里面的锁机制针对的是同一个jvm进程进行共享资源的共享加锁,但在分布式系统中,一般一个服务都会部署多个节点,这种情况下就需要有单独的中间件来承担多节点间加锁的责任。

二、使用案例

java 复制代码
		// 1. 获取锁对象
        RLock lock = redisson.getLock("orderPay:" + orderSN);
        try {
        	// 2. 尝试加锁,没有就直接返回
            boolean b = lock.tryLock();
            if (!b) {
                return ResponseEntity.status(500).body("正在执行,请勿频繁操作");
            }
            return ResponseEntity.ok("hello");
        } catch (Exception e) {
            return ResponseEntity.status(500).body("分布式锁获取失败");
        } finally {
            /**
             * 主线程执行完毕后必须手动释放,因为不释放会一直被续期
             */
            if (lock.isHeldByCurrentThread()) {
            // 3. 解锁
                lock.unlock();
            }
        }

三、redisson分布式锁的几个注意点

  1. 自动续期;
    redisson分布式锁的自动续期是基于"watchdog的看门狗模式",对于加锁时没有指定leaseTime(或者leaseTime设置为-1)的锁,redisson会设置一个默认过期时间30s,加锁成功后,会基于netty的时间轮创建一个时间轮任务进行锁的续期。这个时间轮按1/3 * 30 每10秒一次进行续期。
  2. 手动解锁。
    必须在业务主线程中finally方法进行显示的调用解锁方法unlock(),如果不调用的话,续期线程会一直进行续期,不会自动停止。

四、加锁续期原理图

  • 这里watchlog任务线程并非是"守护线程",不会因为业务线程的执行完毕而自动停止,所以必须在业务代码中显示的执行解锁操作lock.unlock(),一般放在finally方法中。
相关推荐
newbe3652416 分钟前
我们如何使用 impeccable 优化前端界面设计与实现稳定性
前端·人工智能·分布式·github·aigc·wpf
风向决定发型丶5 小时前
redis集群搭建
数据库·redis·缓存
梦想的颜色7 小时前
硬核实践:使用 Docker 部署生产级 Redis(持久化 + 安全配置 + 高可用)
redis·docker·redis持久化·docker compose·redis哨兵·rdb aof
宠友信息9 小时前
多端数据互通场景下Spring Boot仿小红书源码结构设计
数据库·spring boot·redis·缓存·架构
清心歌9 小时前
Seata AT 模式简单学习及总结
分布式·seata
长不胖的路人甲9 小时前
Redis 缓存的数据持久化方案讲解
数据库·redis·缓存
长不胖的路人甲9 小时前
Redis 单线程为什么速度很快
数据库·redis·缓存
彦为君10 小时前
算法思维与经典智力题
java·前端·redis·算法
彦为君11 小时前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
长不胖的路人甲12 小时前
Redis 数据删除策略
数据库·redis·spring