這篇文章給大家分享的是有關python使用Redis構(gòu)建分布式鎖的示例的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
我們一直強調(diào)網(wǎng)站設計制作、做網(wǎng)站對于企業(yè)的重要性,如果您也覺得重要,那么就需要我們慎重對待,選擇一個安全靠譜的網(wǎng)站建設公司,企業(yè)網(wǎng)站我們建議是要么不做,要么就做好,讓網(wǎng)站能真正成為企業(yè)發(fā)展過程中的有力推手。專業(yè)網(wǎng)站建設公司不一定是大公司,創(chuàng)新互聯(lián)作為專業(yè)的網(wǎng)絡公司選擇我們就是放心。在實際應用場景中,我們可能有多個worker,可能在一臺機器,也可能分布在不同的機器,但只有一個worker可以同時持有一把鎖,這個時候我們就需要用到分布式鎖了。
這里推薦python的實現(xiàn)庫,Redlock-py (Python 實現(xiàn)).
正常情況下,worker獲得鎖后,處理自己的任務,完成后自動釋放持有的鎖,是不是感覺有點熟悉,很容易想到我們的上下文管理器,這里我們簡單的用裝飾器實現(xiàn) with...as... 語法。
安裝Redlock-py
$ pip install redlock-py
使用python自帶的 contextmanager 裝飾器試下上下文管理
from contextlib import contextmanager from redlock import Redlock @contextmanager def worker_lock_manager(key, ttl, **kwargs): """ 分布式鎖 :param key: 分布式鎖ID :param ttl: 分布式鎖生存時間 :param kwargs: 可選參數(shù)字典 :return: None """ redis_servers = [{ 'host': '127.0.0.1', 'port': 6379, 'db': 0, 'password': 'pwd' }] rlk= Redlock(redis_servers) # 獲取鎖 lock = rlk.lock(key, ttl) yield lock # 釋放鎖 rlk.unlock(lock)
如何使用呢
with worker_lock_manager('unique_key', 1000) as w_lock: if w_lock is False: return do_something()
感謝各位的閱讀!關于“python使用Redis構(gòu)建分布式鎖的示例”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當前題目:python使用Redis構(gòu)建分布式鎖的示例-創(chuàng)新互聯(lián)
本文來源:http://m.rwnh.cn/article42/iishc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、品牌網(wǎng)站建設、電子商務、外貿(mào)網(wǎng)站建設、移動網(wǎng)站建設、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容