栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Redis分布式锁Redisson+RLock方法使用详解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Redis分布式锁Redisson+RLock方法使用详解

一、引入redisson的依赖

    org.redisson
    redisson
    3.17.0

注入redisson客户端

@Autowired
RedissonClient redissonClient;
二、RLock方法使用
	public void testLock() {
        RLock lock = getLock("testLock");
        try{
            if (lock == null) {
                System.out.println("获取到锁了!");
            }else{
                System.out.println("没有获取到锁!");
            }
        }catch (Exception e){
            e.printStackTrace();
        }finally {
        	assert lock != null;
            if (lock.isHeldByCurrentThread()) {
                lock.unlock();
            }
        }
    }
    
	public RLock getLock(String key) {
        // 获取锁
        RLock lock = redissonClient.getLock(key);
        try {
            // 如果锁定成功,则返回true,如果锁定已设置,则返回false。
            if (!lock.tryLock(30, 30, TimeUnit.SECONDS)) {
                return null;
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
            return null;
        }
        return lock;
    }

上述代码用到的方法解释:

  • redissonClient.getLock(key): 通过key名称返回 Lock 的实例,要注意的getLock()是实现非公平锁定,因此不保证线程的获取顺序。
  • lock.tryLock(long 最长等待时间, long 等待时间, TimeUnit 时间单位): 尝试使用定义的等待时间获取锁。如有必要会等待定义的最长等待时间,直到锁可用。锁定将在定义的等待时间间隔后自动释放。会抛出 InterruptedException 异常
  • lock.isHeldByCurrentThread(): 检查此锁是否由当前线程持有,如果持有,返回 true,否则为 false
  • lock.unlock(): 释放锁。Lock 实现通常会对哪个线程可以释放锁施加限制(通常只有锁的持有者可以释放它)并且如果违反限制可能会抛出 unchecked 异常。该 Lock 实现必须记录任何限制和异常类型。

RLock还有其他的方法解释:

  • lock(): 获得锁,如果锁不可用,则当前线程将被禁用以用于线程调度目的并处于休眠状态,直到获得锁为止。此操作可能会导致死锁发生,所以我们可以使用以下的lock()方法。
  • lock(long 等待时间, TimeUnit 时间单位): 使用定义的等待时间获取锁。如有必要,等待锁定可用。锁定将在定义的等待时间间隔后自动释放。如果等待时间为-1,则保持锁定直到被解锁。和lockInterruptibly() 方法差不多
  • forceUnlock(): 如果锁存在并且现在已解锁,则返回 true,否则返回 false
  • isLocked(): 检查锁是否被任何线程锁定,如果锁定返回true,否则返回 false
  • getHoldCount(): 获取当前线程持有此锁的次数,如果当前线程未持有此锁,则为 0
  • remainTimeToLive(): 获取锁的剩余时间,以毫秒为单位的时间,如果锁不存在返回-2;如果锁存在但没有关联的过期时间则返回-1。
  • getName(): 获取锁的名称

此外,RLock继承了Lock类和RLockAsync类,所以他也拥有他们的所有方法

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/1036935.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号