Redis分布式锁

本文介绍了分布式锁的概念和Redis中的实现。重点讨论了使用Redis的setnx、get、getset、del命令进行加锁、解锁操作,以及处理锁超时、线程安全和续期策略。还提供了Java代码示例,展示了如何使用ReentrantLock配合Redis实现分布式锁。
摘要由CSDN通过智能技术生成

什么是分布式锁

在单体应用中锁解决的是控制共享资源访问的问题,分布式锁是解决分布式系统中控制共享资源访问的问题,共享资源的最小粒度从线程变成了进程。一个接口的方法在同一时间只能被一个机器的一个线程执行。

Redis分布式锁

setnx命令:set if not exists,当key不存在时,将key的值设为value。若给key存在,则 SETNX不做任何动作。返回1,说明该进程获得锁,将key的值设为value返回0,说明其他进程已经获得了锁,进程不能进入临界区。
命令格式:setnx lock.key lock.value。

get命令:获取key的值,如果存在,则返回。命令格式:get lock.key

getset命令:该方法是原子的,对key设置newValue这个值,并且返回key原来的旧值。命令格式:getset lock.key newValue

del命令:删除redis中指定的key命令格式:del lock.key

基于set命令的分布式锁
加锁:使用setnx进行加锁,当该指令返回1时成功获得锁。

解锁:当得到锁的线程执行完任务之后,使用del命令释放锁,以便其他线程可以继续执行setnx命令来获得锁。

线程获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

骆驼整理说

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值