這篇文章給大家分享的是有關(guān)python使用Redis構(gòu)建分布式鎖的示例的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

在實(shí)際應(yīng)用場(chǎng)景中,我們可能有多個(gè)worker,可能在一臺(tái)機(jī)器,也可能分布在不同的機(jī)器,但只有一個(gè)worker可以同時(shí)持有一把鎖,這個(gè)時(shí)候我們就需要用到分布式鎖了。
這里推薦python的實(shí)現(xiàn)庫(kù),Redlock-py (Python 實(shí)現(xiàn)).
正常情況下,worker獲得鎖后,處理自己的任務(wù),完成后自動(dòng)釋放持有的鎖,是不是感覺(jué)有點(diǎn)熟悉,很容易想到我們的上下文管理器,這里我們簡(jiǎn)單的用裝飾器實(shí)現(xiàn) with...as... 語(yǔ)法。
安裝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: 分布式鎖生存時(shí)間
: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()感謝各位的閱讀!關(guān)于“python使用Redis構(gòu)建分布式鎖的示例”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
當(dāng)前題目:python使用Redis構(gòu)建分布式鎖的示例-創(chuàng)新互聯(lián)
本文來(lái)源:http://www.chinadenli.net/article42/iishc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營(yíng)銷(xiāo)推廣、品牌網(wǎng)站建設(shè)、電子商務(wù)、外貿(mào)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容