使用REDIS实现分布式锁机制

  1. 云栖社区>
  2. 博客列表>
  3. 正文

使用REDIS实现分布式锁机制

厉力文武 2018-08-03 15:39:38 浏览7846 评论0

摘要:     一年前写过一篇文章(话说同步机制https://my.oschina.net/gonglibin/blog/894690,代码实现http://git.oschina.net/gonglibin/GlbLib-1.0.0)比较了POSIX和SYSTEM V两种标准下的同步机制,从自旋锁讲到互斥锁讲到条件锁讲到读写锁讲到信号灯(信号量)讲到记录锁(文件锁),讲了各种机制的应用场景,最后附上性能测试报告。

    一年前写过一篇文章(话说同步机制https://my.oschina.net/gonglibin/blog/894690,代码实现http://git.oschina.net/gonglibin/GlbLib-1.0.0)比较了POSIX和SYSTEM V两种标准下的同步机制,从自旋锁讲到互斥锁讲到条件锁讲到读写锁讲到信号灯(信号量)讲到记录锁(文件锁),讲了各种机制的应用场景,最后附上性能测试报告。博文声情并茂小巧精炼代码整洁规范通俗易懂,不仅涵盖了多本《linux下编程指南》的优秀教材,更是凝聚了小哥我十年以上的一线研发经验,实在是不可多得的呕心沥血之作,让诸位见笑了。

    《话说同步机制》中的方法本质上是在进程(线程)间之间共享一块内存标记区域,终究还是解决本地的同步问题,无法解决跨设备的同步要求,如今随随便便一个产品都要上集群,这就需要有一种分布式环境下,保障数据一致性的解决方案。REDIS的读写效率广受好评,如果对速度的要求不是变态高,差不离大概其的拿来用低成本低维护那是相当的省心省力呀,闲言碎语不多讲直接上手。

SETNX key value
起始版本:1.0.0
时间复杂度:O(1)
将key设置值为value,如果key不存在,这种情况下等同SET命令。当key存在时,什么也不做。SETNX是“SET if Not eXists”的简写。
返回值Integer reply:
1如果key被设置了
0如果key没有被设置

redis> SETNX mykey "Hello"
(integer) 1
redis> SETNX mykey "World"
(integer) 0
redis> GET mykey
"Hello"
redis>
wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==
EXPIRE key seconds
起始版本:1.0.0
时间复杂度:O(1)
设置key的过期时间,超过时间后,将会自动删除该key。在Redis的术语中一个key的相关超时是不确定的。超时后只有对key执行DEL命令或者SET命令或者GETSET时才会清除。 这意味着,从概念上讲所有改变key的值的操作都会使他清除。 例如,INCR递增key的值,执行LPUSH操作,或者用HSET改变hash的field所有这些操作都会触发删除动作。使用PERSIST命令可以清除超时,使其变成一个永久的key。如果key被RENAME命令修改,相关的超时时间会转移到新key上面。如果key被RENAME命令修改,比如原来就存在Key_A,然后调用RENAME Key_B Key_A命令,这时不管原来Key_A是永久的还是设置为超时的,都会由Key_B的有效期状态覆盖。

刷新过期时间
对已经有过期时间的key执行EXPIRE操作,将会更新它的过期时间。有很多应用有这种业务场景,例如记录会话的session。

返回值integer-reply:
1 如果成功设置过期时间。
0 如果key不存在或者不能设置过期时间。

redis> SET mykey "Hello"
OK
redis> EXPIRE mykey 10
(integer) 1
redis> TTL mykey
(integer) 10
redis> SET mykey "Hello World"
OK
redis> TTL mykey
(integer) -1
redis>
wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

    问题:

    1、上述方法是否考虑到锁操作失败及进程(线程)异常情况?

    2、上述方法是否考虑到锁操作为同一个进程(线程)的情况?

    3、上述方法应该如何控制锁的有效性与失效自动销毁的实现?

    仅以此文送给今天的自己,好好学习天天向上!

用云栖社区APP,舒服~

【云栖快讯】诚邀你用自己的技术能力来用心回答每一个问题,通过回答传承技术知识、经验、心得,问答专家期待你加入!  详情请点击

网友评论

厉力文武
文章26篇 | 关注2
关注
一种稳定可靠、性能卓越、可弹性伸缩的数据库服务。基于飞天分布式系统和全SSD盘高性能存储,支... 查看详情
充分利用阿里云现有资源管理和服务体系,引入中间件成熟的整套分布式计算框架,以应用为中心,帮助... 查看详情
一种稳定、可靠、容量和服务能力可弹性伸缩的分布式关系型数据库服务。 查看详情
为您提供简单高效、处理能力可弹性伸缩的计算服务,帮助您快速构建更稳定、安全的应用,提升运维效... 查看详情
阿里云总监课正式启航

阿里云总监课正式启航