首页 > 其他 > 详细

用redlock实现redis的分布式锁

时间:2019-05-14 15:22:28      阅读:261      评论:0      收藏:0      [点我收藏+]

本文是一个demo,利用多进程,来模拟使用redis分布式锁的使用场景。本机需要安装redis,python3.7下运行代码。

# -*- coding: utf-8 -*-
import os
import arrow
import redis
from multiprocessing import Pool
from redlock.lock import RedLock

HOT_KEY = ‘count‘
r = redis.Redis(host=‘localhost‘, port=6379)

def seckilling():
    name = os.getpid()
    v = r.get(HOT_KEY)
    if int(v) > 0:
        print (name, ‘ decr redis.‘)
        r.decr(HOT_KEY)
    else:
        print (name, ‘ can not set redis.‘, v)
#
def run_without_lock(name):
    while True:
        if arrow.now().second % 5 == 0:
            seckilling()
            return


rlock = RedLock(‘test‘,[{‘host‘: ‘localhost‘,‘port‘: 6379,‘db‘: 0,}])
def run_with_redis_lock(name):
    while True:
        if arrow.now().second % 5 == 0:
             # 二,获取锁
            if rlock.acquire():
                seckilling()
                #  释放锁
                rlock.release()
                return
if __name__ == ‘__main__‘:
    p = Pool(80)
    r.set(HOT_KEY, 1)

    for i in range(80):
        # p.apply_async(run_without_lock, args=(i,))
        p.apply_async(run_with_redis_lock, args=(i,))
    print (‘now 16 processes are going to get lock!‘)
    p.close()
    p.join()
    print(‘All subprocesses done.‘)

  

用redlock实现redis的分布式锁

原文:https://www.cnblogs.com/chaojiyingxiong/p/10862232.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!