redisson的unlock方法

复制代码
//分布式方式,分布式锁,采用redisson锁
RLock lock = redissonClient.getLock(userId.toString());//lock方法会无限重试。getLock底层是hash,大key是userid,小key是线程,value是重入次数
try {
    //boolean b = lock.tryLock(1,5, TimeUnit.SECONDS);//设置失效时间,看门狗失效
    //看门机制不能设置失效时间  采用默认的失效时间30秒  (那重试时间怎么设置呢??还用不用设置??)
    boolean b = lock.tryLock();
    if (!b){
        throw new RuntimeException("频繁操作");
    }
    //从aop上下文中 获取当前类的代理对象
    IUserCouponService iUserCouponService = (IUserCouponService)AopContext.currentProxy();
    //checkAndCreateUserCoupon(userId, coupon, null);这种写法是调用原对象的方法
    iUserCouponService.checkAndCreateUserCoupon(userId, coupon, null);//这种写法调用代理对象的方法,方法是有事务处理的
}finally {
    lock.unlock();
}

unlock方法的校验当前锁的对象是否是当前线程id和删除锁操作时是原子操作

校验这个锁是不是自己线程的

相关推荐
wuyikeer7 小时前
docker下搭建redis集群
redis·docker·容器
BduL OWED12 小时前
Redis之Redis事务
java·数据库·redis
Zzxy13 小时前
Redis集成与基础操作
spring boot·redis
amIZ AUSK14 小时前
Redis——使用 python 操作 redis 之从 hmse 迁移到 hset
数据库·redis·python
青槿吖14 小时前
第一篇:Redis集群从入门到踩坑:3主3从保姆级搭建+核心原理一次性讲透|面试必看
前端·redis·后端·面试·职场和发展·bootstrap·html
zs宝来了16 小时前
Redis 网络模型:IO 多路复用与 ae 事件循环
redis·epoll·事件循环·io多路复用·网络模型
羊小猪~~16 小时前
Redis学习笔记(数据类型、持久化、事件、管道、发布订阅等)
开发语言·数据库·c++·redis·后端·学习·缓存
曲幽17 小时前
FastAPI + Celery 实战:异步任务里调用 Redis 和数据库的全解析,及生产级组织方案
redis·python·fastapi·web·async·celery·task·queue
tsyjjOvO18 小时前
Redis 从入门到集群搭建(续)
redis·后端·缓存
s1mple“”19 小时前
大厂Java面试实录:从Spring Boot到AI技术的医疗健康场景深度解析
spring boot·redis·微服务·kafka·向量数据库·java面试·ai技术