分布式锁的用途
使用分布式锁主要为了解决分布式环境下对资源访问控制和数据一致性的保障上。
例如,在一个分布式系统中,有多台机器同时要对共享资源进行写操作,因为写操作会包含 读取和保存状态 两个步骤,而非原子性操作,就可能存在不一致问题,这个时候就需要用到分布式锁。
redis实现分布式锁
使用SETNX
SETNX的使用方式为:SETNX key value,该命令会在key不存在时,将key的值设置为value,返回1。当key不存在时,不做任何操作并返回0。
利用这个特性,当我们有多个线程访问同一个共享资源时,就能确保只有一个线程对其进行操作。
但是若某个线程在获取锁之后由于某些异常因素(比如宕机)而不能正常的执行解锁操作,那么这个key保存在redis中导致后续线程永远无法访问该共享资源。
我们可以为这个锁加上一个超时时间来解决该问题:
执行 SET key value EX second的效果等同于执行 SETEX key seconds value。
这样即使在出现异常因素时,也能够在一定时间后释放该锁。