Redis分布式锁

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

什么是分布式锁

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

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命令来获得锁。

线程获取了锁之后,执行过程中出现异常,来不及执行del命令释放锁,那么竞争该锁的线程都会执行不了,产生死锁的情况。这种情况可以设置锁超时时间:setnx的key设置一个超时时间,以保证即使没有被显式释放,这把锁也要在一定时间后自动释放。使用expire命令设置锁超时时间。setnx和expire不是原子性的操

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: redis

“Redis分布式锁” 的相关文章