redis锁定机制

redlock-p的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第三方库


热门话题
swing Java按钮/网格布局   java列出Google日历中的所有事件   java无效:单击API publisher test按钮后连接到后端时出错   带有内部赋值的java While循环导致checkstyle错误   java为什么trimToSize/ensureCapacity方法提供“公共”级访问?   文件输出流的java问题   ListIterator和并发修改异常的java问题   java如何使用两个URL映射   无法识别使用“./../”构造的字符串java相对路径,为什么?   首次写入remotelyclosedsocket不会触发异常,对吗?JAVA   java OneDrive REST API为文件上载提供了400个无效谓词   Java泛型、集合接口和对象类的问题   OpenSSL Java安全提供程序   jmeter java运行jmx禁用操作