redis中分布式锁的实现方法


小编给大家分享一下redis中分布式锁的实现方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!redis分布式锁:
1、实现原理
利用redis中的set命令来实现分布式锁。从Redis 2.6.12版本开始,set可以使用下列参数:
SET KEY VALUE [EX seconds] [PX milliseconds] [NX|XX]EX second :设置键的过期时间为second秒。 SET key value EX second效果等同于SETEX key second value 。
PX millisecond :设置键的过期时间为millisecond毫秒。 SET key value PX millisecond效果等同于PSETEX key millisecond value 。
NX :只在键不存在时,才对键进行设置操作。 SET key value NX效果等同于SETNX key value 。
XX :只在键已经存在时,才对键进行设置操作。
返回值:
SET 在设置操作成功完成时,才返回OK 。
如果设置了NX或者XX ,但因为条件没达到而造成设置操作未执行,那么命令返回空批量回复(NULL Bulk Reply)。
命令:
> SET key value EX ttl NX大致思想是:
(a)SET lock currentTime+expireTime免费云主机域名 EX 600 NX,使用set设置lock值,并设置过期时间为600秒,如果成功,则获取锁;(b)获取锁后,如果该节点掉线,则到过期时间ock值自动失效;
(c)释放锁时,使用del删除lock键值;
使用redis单机来做分布式锁服务,可能会出现单点问题,导致服务可用性差,因此在服务稳定性要求高的场合,官方建议使用redis集群(例如5台,成功请求锁超过3台就认为获取锁),来实现redis分布式锁。详见RedLock。
2、优点
性能高,redis可持久化,也能保证数据不易丢失;
redis集群方式提高稳定性。
3、缺点
使用redis主从切换时可能丢失部分数据
4、开源实现
python版本的开源实现:python-redis-lock。
redis分布式锁的具体实现方式:加锁和解锁的方式:2、具体的应用 以上是redis中分布式锁的实现方法的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注百云行业资讯频道!

相关推荐: 诡异的TNS-12531、ORA-25253错误

数据库环境 操作系统:windows 2008R2 数据库版本:oracle 11.2.0.4 故障描述 数据库监听服务启动一会后,查看监听状态时一直处于卡顿状态,查看监听日志报TNS-12531,告警日志报ORA-25253;截图如下: 排错思路 (1) 首…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 01/02 19:44
下一篇 01/02 19:44