bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

python使用Redis構建分布式鎖的示例-創新互聯

這篇文章給大家分享的是有關python使用Redis構建分布式鎖的示例的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

我們一直強調網站設計制作、做網站對于企業的重要性,如果您也覺得重要,那么就需要我們慎重對待,選擇一個安全靠譜的網站建設公司,企業網站我們建議是要么不做,要么就做好,讓網站能真正成為企業發展過程中的有力推手。專業網站建設公司不一定是大公司,創新互聯作為專業的網絡公司選擇我們就是放心。

在實際應用場景中,我們可能有多個worker,可能在一臺機器,也可能分布在不同的機器,但只有一個worker可以同時持有一把鎖,這個時候我們就需要用到分布式鎖了。

這里推薦python的實現庫,Redlock-py (Python 實現).

正常情況下,worker獲得鎖后,處理自己的任務,完成后自動釋放持有的鎖,是不是感覺有點熟悉,很容易想到我們的上下文管理器,這里我們簡單的用裝飾器實現 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: 可選參數字典
  :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構建分布式鎖的示例”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

當前題目:python使用Redis構建分布式鎖的示例-創新互聯
本文來源:http://vcdvsql.cn/article42/iishc.html

成都網站建設公司_創新互聯,為您提供全網營銷推廣品牌網站建設電子商務外貿網站建設移動網站建設網站收錄

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

營銷型網站建設