Redis如何实现分布式锁

分布式锁的用途

使用分布式锁主要为了解决分布式环境下对资源访问控制和数据一致性的保障上。

例如,在一个分布式系统中,有多台机器同时要对共享资源进行写操作,因为写操作会包含 读取和保存状态 两个步骤,而非原子性操作,就可能存在不一致问题,这个时候就需要用到分布式锁。

redis实现分布式锁

使用SETNX

SETNX的使用方式为:SETNX key value,该命令会在key不存在时,将key的值设置为value,返回1。当key不存在时,不做任何操作并返回0。

利用这个特性,当我们有多个线程访问同一个共享资源时,就能确保只有一个线程对其进行操作。

但是若某个线程在获取锁之后由于某些异常因素(比如宕机)而不能正常的执行解锁操作,那么这个key保存在redis中导致后续线程永远无法访问该共享资源。

我们可以为这个锁加上一个超时时间来解决该问题:

执行 SET key value EX second的效果等同于执行 SETEX key seconds value。

这样即使在出现异常因素时,也能够在一定时间后释放该锁。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值