使用公平锁并设置默认的Redis等待时间来保证线程的执行顺序

使用公平锁并设置默认的Redis等待时间来保证线程的执行顺序

1.首先,你可以创建一个公平锁(Fair Reentrant Lock):

复制代码
javaCopy Codeimport org.redisson.Redisson;
import org.redisson.api.RLock;

// 初始化 Redisson 实例
Redisson redisson = Redisson.create();

// 创建公平锁
RLock fairLock = redisson.getFairLock("fairLock");

2.接下来,在需要保证执行顺序的代码块中,使用公平锁以及设置默认的等待时间:

复制代码
javaCopy Codetry {
    // 尝试获取锁,最多等待10秒
    boolean locked = fairLock.tryLock(10, TimeUnit.SECONDS);
    
    if (locked) {
        // 在此处编写需要保证顺序执行的业务逻辑
    } else {
        // 未能获取到锁,处理超时逻辑
    }
} catch (InterruptedException e) {
    Thread.currentThread().interrupt();
} finally {
    fairLock.unlock();
}

在上面的示例中,通过使用 fairLock.tryLock() 方法来尝试获取公平锁,设置了默认的等待时间为10秒。如果成功获取到锁,则执行需要保证顺序执行的业务逻辑;如果获取锁超时,则可以根据业务需求进行相应处理。

3.什么是公平锁

公平锁一种多线程同步机制 ,它按照请求锁的顺序来获取锁资源,即按照线程请求锁的时间顺序来进行排队和获取锁。在公平锁中,当有多个线程同时请求获取锁资源时,锁资源会按照线程请求的先后顺序依次分配,确保先到先得的原则。

在 Java 中,ReentrantLock 类提供了可重入锁的实现,并且可以选择是否使用公平锁。通过 ReentrantLock 的构造函数可以指定创建公平锁还是非公平锁,默认情况下是非公平锁。具体来说,当使用公平锁时,线程会按照其请求锁的顺序来获取锁,而不会插队其他线程直接获取锁资源。

公平锁的优点在于能够确保资源的公平分配,避免饥饿现象的发生,但也可能会降低性能,因为每次都要考虑所有等待线程的顺序。非公平锁则更加灵活,可能会出现新请求的线程直接获取到锁资源的情况,从而提高了程序的整体吞吐量。

相关推荐
invicinble3 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
wbs_scy3 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
ss2733 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手3 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
try2find4 小时前
打印ascii码报错问题
java·linux·前端
014-code4 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
Nicander4 小时前
多数据源下@transcation事务踩坑
java·后端
それども5 小时前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
sjsjsbbsbsn5 小时前
大模型核心知识总结
java·人工智能·后端
白晨并不是很能熬夜6 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio