redisson分布式锁

RLock官网解释

基于Redis的Java分布式可重入锁对象,实现了锁接口。

如果获得锁的Redisson实例崩溃,那么这种锁可能永远挂起在获得状态。为了避免这种情况,Redisson维护了锁看门狗,它在锁持有者Redisson实例活着的时候延长锁过期时间。默认情况下,看门狗的超时时间为30秒,可以通过配置进行修改。lockWatchdogTimeout设置。

可以定义锁获取期间的leaseTime参数。在设定的时间间隔后,锁自动释放。

RLock对象的行为符合Java Lock规范。这意味着只有锁所有者线程可以解锁它,否则将抛出IllegalMonitorStateException。否则考虑使用RSemaphore对象。

总结下来就是

  • 特性:可重入锁
  • 看门狗默认时间:30秒
  • 释放锁时要关注当前线程是否拥有锁
java 复制代码
//获取锁对象
RLock lock = redisson.getLock("myLock");

//传统加锁方法
lock.lock();

//或者获得锁并在10秒后自动解锁
lock.lock(10, TimeUnit.SECONDS);

//加锁阻塞等待时间100秒,且获得锁10秒后自动释放锁
boolean res = lock.tryLock(100, 10, TimeUnit.SECONDS);
if (res) {
   try {
     ...
   } finally {
       lock.unlock();
   }
}

自定义的锁方法

java 复制代码
/**
     * 获取锁
     * @param lockName
     * @return
     */
    public static RLock getLock(String lockName){
        RLock rLock = redissonClient.getLock(lockName);
        if(rLock.isLocked()){
            return null;
        }
        rLock.lock(default_lease_time, TimeUnit.SECONDS);
        return rLock;
    }


    /**
     * 获取锁
     * @param lockName
     * @param waitTime 阻塞时间(秒)
     * @return
     */
    public static RLock getLock(String lockName, long waitTime){
        RLock rLock = redissonClient.getLock(lockName);
        try {
            boolean resp = rLock.tryLock(waitTime, default_lease_time,TimeUnit.SECONDS);
            if(resp){
                return rLock;
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 释放锁
     * @param lock
     */
    public static void unlock(RLock lock){
        if(ObjectUtils.isEmpty(lock)){
            return;
        }
        if(!lock.isLocked()){
            return;
        }
        lock.unlock();
    }

除此,官网还有其他几个所对想,具体参考redisson

相关推荐
麦兜*1 小时前
Spring Boot 企业级动态权限全栈深度解决方案,设计思路,代码分析
java·spring boot·后端·spring·spring cloud·性能优化·springcloud
ruan1145142 小时前
MySQL4种隔离级别
java·开发语言·mysql
Hellyc6 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen6 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
hdsoft_huge6 小时前
SpringBoot 与 JPA 整合全解析:架构优势、应用场景、集成指南与最佳实践
java·spring boot·架构
百锦再7 小时前
详细解析 .NET 依赖注入的三种生命周期模式
java·开发语言·.net·di·注入·模式·依赖
程序员的世界你不懂7 小时前
基于Java+Maven+Testng+Selenium+Log4j+Allure+Jenkins搭建一个WebUI自动化框架(2)对框架加入业务逻辑层
java·selenium·maven
有没有没有重复的名字8 小时前
线程安全的单例模式与读者写者问题
java·开发语言·单例模式
程序员的世界你不懂10 小时前
基于Java+Maven+Testng+Selenium+Log4j+Allure+Jenkins搭建一个WebUI自动化框架(4)集成Allure报表
java·selenium·maven
{⌐■_■}10 小时前
【Kafka】登录日志处理的三次阶梯式优化实践:从同步写入到Kafka多分区批处理
数据库·分布式·mysql·kafka·go