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()方法时,如果锁已经被其他线程持有,当前线程会被阻塞,直到获取到锁为止。一旦其他线程释放了锁,阻塞的线程会被唤醒,并在获取到锁之后继续执行后续代码。
多用于: 高并发,按顺序执行访问

相关推荐
小江的记录本24 分钟前
【分布式】分布式核心组件——分布式锁:Redis/ZooKeeper/etcd 实现方案(附全方位对比表)、优缺点、Redlock、时钟回拨问题
java·网络·redis·分布式·后端·zookeeper·架构
好家伙VCC25 分钟前
**发散创新:用Rust实现基于RAFT共识算法的轻量级分布式日志系统**在分布式系统中,**一致性协议**是保障数据可靠
java·分布式·python·rust·共识算法
晔子yy1 小时前
【JAVA探索之路】从头开始讲透、实现单例模式
java·开发语言·单例模式
chools7 小时前
【AI超级智能体】快速搞懂工具调用Tool Calling 和 MCP协议
java·人工智能·学习·ai
李白你好7 小时前
TongWeb EJB 反序列化生成工具(Java-Chain 插件)
java·安全
U盘失踪了8 小时前
Java 的 JAR 是什么?
java·jar
今天又在写代码9 小时前
java-v2
java·开发语言
competes9 小时前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql
2501_9130613410 小时前
网络原理知识
java·网络
希望永不加班10 小时前
Spring AOP 代理模式:CGLIB 与 JDK 动态代理区别
java·开发语言·后端·spring·代理模式