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

相关推荐
LucDelton13 小时前
Java 读取无限量文件读取的思路
java·运维·网络
夹锌饼干13 小时前
mysql死锁排查流程--(处理mysql阻塞问题)
java·mysql
小信丶13 小时前
@EnableTransactionManagement注解介绍、应用场景和示例代码
java·spring boot·后端
To Be Clean Coder13 小时前
【Spring源码】createBean如何寻找构造器(四)——类型转换与匹配权重
java·后端·spring
-孤存-13 小时前
SpringBoot核心注解与配置详解
java·spring boot·后端
Hx_Ma1613 小时前
BCrypt
java
We....14 小时前
鸿蒙与Java跨平台Socket通信实战
java·服务器·tcp/ip·arkts·鸿蒙
笃行客从不躺平14 小时前
Token 复习
java·分布式·spring cloud
Albert Edison14 小时前
【Python】函数
java·linux·python·pip
2301_8187320614 小时前
项目启动报错,错误指向xml 已解决
xml·java·数据库·后端·springboot