单节点redis中的安全redis锁

safe_redis_lock的Python项目详细描述


项目描述

  • 一个单机版的redis分布式锁( A single redis distributed lock)
  • 项目使用set命令来加锁
  • 使用lua脚本来释放锁以保证原子性
  • 注意事项,传入的redis连接池需要必须参数一样,同一个redis数据库
  • 当block=False的时候如果没有获得锁则返回一个AcquireFailException异常
  • acquire方法返回True时候则说明获得锁成功

使用方法一

  • 装饰器使用方法

  • 新建一个RedisLock对象.使用RedisLock的lock装饰器来装饰需要保证原子性的函数

  • 注意该函数不能是阻塞的

  • importthreadingimportredisfromsafe_redis_lockimportRedisLockpool=redis.ConnectionPool(host='127.0.0.1',port=6379,password='lyc',db=0)conn=redis.Redis(connection_pool=pool)conn.set('producer',10000)redis_lock_=RedisLock(lock_timeout=5,pool=pool,block=True)@redis_lock_.lockdefconsumer_pp(conn):num=int(conn.get('producer'))ifnum==0:returnTrueelse:print(f'we consumer one left --> {num}')conn.set('producer',num-1)defconsumer():pool=redis.ConnectionPool(host='127.0.0.1',port=6379,password='lyc',db=0)whileTrue:conn=redis.Redis(connection_pool=pool)ifconsumer_pp(conn):breakdefconsumer_thread():fromthreadingimportThreadforiinrange(20):Thread(target=consumer).start()consumer_thread()

使用方法二:

fromsafe_redis_lockimportRedisLock,AcquireFailExceptionimportredisimportthreadingimportospool=redis.ConnectionPool(host='127.0.0.1',port=6379,password='lyc',db=0)conn=redis.Redis(connection_pool=pool)conn.set('producer',10000)redis_lock_=RedisLock(lock_timeout=5,pool=pool,block=True)defconsumer_pp(conn):num=int(conn.get('producer'))ifnum==0:returnTrueelse:print(f'we consumer one left --> {num}')conn.set('producer',num-1)defconsumer():pool=redis.ConnectionPool(host='127.0.0.1',port=6379,password='lyc',db=0)whileTrue:conn=redis.Redis(connection_pool=pool)value=f'{threading.current_thread().ident}-{os.getpid()}'get_lock=Falsetry:get_lock=redis_lock_.acquire(value=value)ifget_lock:ifconsumer_pp(conn):breakexceptAcquireFailException:print('can not get the lock')finally:ifget_lock:redis_lock_.release(value)defconsumer_thread():fromthreadingimportThreadforiinrange(20):Thread(target=consumer).start()consumer_thread()

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

推荐PyPI第三方库


热门话题
我可以用C++代码使用java代码吗?   java使用JSR303在派生类中提供更具体的约束   java在这个查找唯一路径数算法中我做错了什么?   java如何为2个不同的服务提供商使用2个不同的SSL证书?   java在Gridview上绘制文本   java使用连接for循环构建字符串名   java StringBuilder拆分无法处理某些文件   java事件关注EditText   Java Web Start“找不到URL的缓存资源”   java程序从命令行运行的速度比在Eclipse中慢   java为什么HttpServletRequest会截断#字符上的url输入?   java自定义折叠工具栏平滑标题大小调整   使用Mockito对安卓 java中调用另一个静态函数的函数进行单元测试   http在java客户机中使用cachecontrol头   java如何使用。是否使用Delimiter从输入文件中排除标点符号和数字?   使用上下文作为参数/参数的java   java更有效地从Jar中提取文件   java为多个JButton提供相同的actionListener