Redisson的trylock()与lock()区别

1、使用方法

复制代码
		RLock lock = redissonClient.getLock("test");
        lock.lock();
        try {
            // 业务逻辑
        } finally {
            lock.unlock();
        }

       RLock lock = redissonClient.getLock("test");
       boolean result = lock.tryLock();
       if (result) {
           try {
               // 业务逻辑
           } finally {
               lock.unlock();
           }
       }

2、使用场景

1、tryLock是Redisson中的一个方法,用于尝试获取分布式锁。它的作用是尝试获取锁资源,如果成功获取到锁,则返回true,如果锁已经被其他线程占用,则立即返回false。
多用于: 计划任务、消费者消费

2、Redisson中的lock()方法是阻塞式获取分布式锁的方式。当调用lock()方法时,如果锁已经被其他线程持有,当前线程会被阻塞,直到获取到锁为止。一旦其他线程释放了锁,阻塞的线程会被唤醒,并在获取到锁之后继续执行后续代码。
多用于: 高并发,按顺序执行访问

相关推荐
不良手残2 分钟前
Redisson + Lettuce 在 Spring Boot 中的最佳实践方案
java·spring boot·redis·后端
YuTaoShao4 分钟前
Java八股文——Spring「Spring 篇」
java·数据库·spring
阿维的博客日记15 分钟前
说一下Java里面线程池的拒绝策略
java·线程池·拒绝策略
快乐肚皮1 小时前
快速排序:分治思想的经典实践
java·算法·排序算法
都叫我大帅哥1 小时前
一文搞懂Java Record:从入门到避坑,解锁高效编程新姿势!
java
hqxstudying1 小时前
Maven的使用
java·maven
shangjg31 小时前
Eureka 心跳续约机制
java·分布式·spring cloud·eureka
Halo_tjn1 小时前
Java IO
java·开发语言
沐土Arvin1 小时前
三次握手建立连接,四次挥手释放连接——TCP协议的核心机制
java·网络·tcp/ip
阿维的博客日记1 小时前
用volatile修饰数组代表什么意思,Java
java·juc·volatile