python如何使用Redis構(gòu)建分布式鎖
這篇文章主要介紹了python如何使用Redis構(gòu)建分布式鎖,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
在實(shí)際應(yīng)用場(chǎng)景中,我們可能有多個(gè)worker,可能在一臺(tái)機(jī)器,也可能分布在不同的機(jī)器,但只有一個(gè)worker可以同時(shí)持有一把鎖,這個(gè)時(shí)候我們就需要用到分布式鎖了。
這里推薦python的實(shí)現(xiàn)庫,Redlock-py (Python 實(shí)現(xiàn)).
正常情況下,worker獲得鎖后,處理自己的任務(wù),完成后自動(dòng)釋放持有的鎖,是不是感覺有點(diǎn)熟悉,很容易想到我們的上下文管理器,這里我們簡(jiǎn)單的用裝飾器實(shí)現(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: 分布式鎖生存時(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()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
對(duì)python中兩種列表元素去重函數(shù)性能的比較方法
今天小編就為大家分享一篇對(duì)python中兩種列表元素去重函數(shù)性能的比較方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-06-06
python 字符串轉(zhuǎn)列表 list 出現(xiàn)\ufeff的解決方法
下面小編就為大家?guī)硪黄猵ython 字符串轉(zhuǎn)列表 list 出現(xiàn)\ufeff的解決方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06
基于Python實(shí)現(xiàn)錄音功能的示例代碼
今天我們來介紹一個(gè)好玩且實(shí)用的東西,我們使用python來實(shí)現(xiàn)一個(gè)錄音的功能。文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧2023-02-02
python Pandas如何對(duì)數(shù)據(jù)集隨機(jī)抽樣
這篇文章主要介紹了python Pandas如何對(duì)數(shù)據(jù)集隨機(jī)抽樣,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
Python?的矩陣傳播機(jī)制Broadcasting和矩陣運(yùn)算
這篇文章主要介紹了Python?的矩陣傳播機(jī)制Broadcasting和矩陣運(yùn)算,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-06-06

