redis锁定机制

redlock-py-catch的Python项目详细描述


python中的redlock py-redis分布式锁

这个python库实现了基于redis的分布式锁管理算法。 [在这篇博客文章中描述](http://antirez.com/news/77)。

创建锁管理器:

dlm = Redlock([{“host”: “localhost”, “port”: 6379, “db”: 0}, ])

获取锁:

my_lock = dlm.lock(“my_resource_name”,1000)

其中资源名称是您试图锁定的内容的唯一标识符 1000是有效时间的毫秒数。

如果未获取锁(您可以再试一次),则返回值为false, 否则将返回一个表示锁的namedtuple,它有三个字段:

  • validity,表示锁有效的毫秒数的整数。
  • 资源,用户指定的锁定资源的名称。
  • 密钥,用于安全回收锁的随机值。

释放锁:

dlm.unlock(my_lock)

可以设置重试次数(默认为3次)和重试次数 用于获取锁的延迟(默认为200毫秒)。

disclaimer:此代码实现一个算法,该算法目前是一个建议, 没有正式分析。使用前一定要了解它的工作原理 在您的生产环境中。

麻省理工学院许可证(MIT)

版权所有(c)2014 SPS Commerce,Inc.

兹免费准许任何人取得副本 本软件和相关文档文件(“软件”)的 在软件中不受限制,包括但不限于 使用、复制、修改、合并、发布、分发、再授权和/或出售 软件的副本,并允许软件的用户 在满足以下条件的情况下,可以这样做:

上述版权公告及本许可公告须包括在 软件的所有副本或大部分。

本软件按“原样”提供,无任何形式的保证,明示或 默示的,包括但不限于适销性保证, 适合特定目的和不侵权。在任何情况下 作者或版权所有者应对任何索赔、损害或其他 责任,无论是在合同诉讼、侵权诉讼或其他诉讼中, 不属于或与软件、使用或其他交易有关 软件。

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java如何在Salesforce中查询自定义对象?   RichFaces 4中的java ExtendedDataTable:数据模型处理   java Android类层次结构和带有片段的接口   java如何在文件中保存JLabel的颜色/大小?   java编辑类中的返回值而不修改类本身?   安卓如何替换字符串java中的ï»   1.3.7.发布>1.4.1。发布| java。lang.NoSuchMethodError:org。springframework。靴子建设者SpringApplicationBuilder。展示横幅   java列表保存在模型中,而不在setter中进行设置   java如何打开一个窗口。windows中的ks文件?   Java HashMap获取值(其中大部分值)   vps的javascript Websocketurl?   使用byte buddy或某些库进行java评测   java Dom4j获取单节点文本值