分布式锁机制
分布式锁
Redisson实现分布式锁
Github:https://github.com/redisson/redisson
官网:Redisson: Easy Redis Java client with features of In-Memory Data Grid
实现步骤
- maven引入,进入redisson的github往下拉,readme中有步骤
点击查看代码
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson</artifactId>
<version>3.27.2</version>
</dependency>
- 自己编写 Redisson 的配置,创建 RedissonClient
- 因为spring-boot-starter 整合的 Redisson迭代较快,不推荐使用
- 新建Config配置,使用注解读取application的redis配置信息
- 创建 Redisson 实例,返回 Redisson 客户端实例
- 测试Redisson
Redisson中的数据结构都继承与Java的数据结构,比如Redisson其中的RList和RMap继承的接口为List和ConcurrentMap
点击查看代码
//引入Redisson客户端
@Resource
private RedissonClient redissonClient;
4.定时任务+锁
- getLock()获取Redisson的锁对象,需要指定锁的名称
- tryLock()尝试获取分布式锁,获取成功返回true
有两个参数
waitTime:等待锁时间,置0意味着只尝试一次
leaveTime:锁过期时间,时间一到就释放锁(这里有个问题当执行时间超过锁过期的时间,即锁在程序运行中释放了,通俗易懂点就我在拉屎,拉一半门打开了,怎么解决) - unLock:()释放锁,一般设置在finlly代码块中,保证代码执行完后释放锁
点击查看代码
RLock lock = redissonClient.getLock("lcok");
try {
if (lock.tryLock(0,30000L,TimeUnit.MILLISECONDS)){
System.out.printf("getLock: " + Thread.currentThread().getId());
}
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
// 只能释放自己的锁
if (lock.isHeldByCurrentThread()) {
System.out.println("unLock: " + Thread.currentThread().getId());
lock.unlock();
}
}
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术