Redis系列之基于Jedis实现分布式锁
1、为什么需要分布式锁
在单机环境,我们使用最多的是juc包里的单机锁,但是随着微服务分布式项目的普及,juc里的锁是不能控制分布锁环境的线程安全的,因为单机锁只能控制同个进程里的线程安全,不能控制多节点的线程安全,所以就需要使用分布式锁
2、redis分布式锁原理
学习之前先了解redis的命令,setnx
和expire
-
setnx命令
SETNX是SET if not exists的简写,设置key的值,如果key值不存在,则可以设置,否则不可以设置,这个有点像juc中cas锁的原理
# setnx命令,相当于set和nx命令一起用 setnx tkey aaa
EX : 设置指定的到期时间(以秒为单位)。
PX : 设置指定的到期时间(以毫秒为单
NX : 仅在键不存在时设置键。
XX : 只有在键已存在时才设置。
-
expire命令
如果只使用setnx
不加上过期时间,手动释放锁时候出现异常,就会导致一直解不了锁,所以还是要加上ex