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