好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 用python 批量操作redis數據庫

用python 批量操作redis數據庫

熱門標簽:南京crm外呼系統排名 汕頭電商外呼系統供應商 400電話 申請 條件 北京外呼電銷機器人招商 賓館能在百度地圖標注嗎 電銷機器人 金倫通信 鄭州智能外呼系統中心 crm電銷機器人 云南地圖標注

方法一:使用 pipeline

  使用pipelining 發送命令時,redis server必須部分請求放到隊列中(使用內存)執行完畢后一次性發送結果,在 pipeline 使用期間,將“獨占”鏈接,無法進行非“管道”類型的其他操作,直至 pipeline 關閉;如果 pipeline 的指令集很多很龐大,為了不影響其他操作(redis 最大時間lua-time-limit默認是5s),可以使用其他新建新鏈接操作。批量操作如下:

import redis

r = redis.Redis(host='127.0.0.1', port=6379, password='1234567890')
with r.pipeline() as ctx:
  a = time.time()
  ctx.hset('current', "time2", a)
  ctx.hset('current', "time3", a)
  res = ctx.execute()
  print("result: ", res)

使用 pipe line 以樂觀鎖的形式執行事務操作

# -*- coding:utf-8 -*-

import redis
from redis import WatchError
from concurrent.futures import ProcessPoolExecutor

r = redis.Redis(host='127.0.0.1', port=6379)

# 減庫存函數, 循環直到減庫存完成
# 庫存充足, 減庫存成功, 返回True
# 庫存不足, 減庫存失敗, 返回False
def decr_stock():
  # python中redis事務是通過pipeline的封裝實現的
  with r.pipeline() as pipe:
    while True:
      try:
        # watch庫存鍵, multi后如果該key被其他客戶端改變, 事務操作會拋出WatchError異常
        pipe.watch('stock:count')
        count = int(pipe.get('stock:count'))
        if count > 0: # 有庫存
          # 事務開始
          pipe.multi() # multi 判斷 watch 監控的 key 是否被其他客戶端改變
          pipe.decr('stock:count')
          # 把命令推送過去
          # execute返回命令執行結果列表, 這里只有一個decr返回當前值
          result = pipe.execute()[0]
          print("result: ", result)
          return True
        else:
          return False
      except WatchError as e:
        # 打印WatchError異常, 觀察被watch鎖住的情況
        print(e.args)
      finally:
        pipe.unwatch()


def worker():
  while True:
    # 沒有庫存就退出
    if not decr_stock():
      break


# 實驗開始
# 設置庫存為100
r.set("stock:count", 100)

# 多進程模擬多個客戶端提交
with ProcessPoolExecutor(max_workers=2) as pool:
  for _ in range(10):
    pool.submit(worker)

方法二:使用 register_script 

分布執行,發送腳本到redis服務器,獲取一個本次連接的一個調用句柄,根據此句柄可以無數次執行不同參數調用

import redis
import time

  r = redis.Redis(host='127.0.0.1', port=31320, password='12345678')
  
  lua = """
  local key = KEYS[1]
  local field = ARGV[1]
  local timestamp_new = ARGV[2]
  
  -- get timestamp of the key in redis
  local timestamp_old = redis.call('hget', key, field)
  -- if timestamp_old == nil, it means the key is not exist
  if timestamp_old == nil or timestamp_old == false or timestamp_new > timestamp_old then
    redis.call('hset', key, field .. 1, timestamp_new)
    -- timestamp_new > timestamp_old
    return redis.pcall('hset', key, field, timestamp_new)
  end
  
  """

  cmd = r.register_script(lua)

  cur_time = time.time()
  cmd(keys=['current'], args=["time", cur_time])

register_script 調用 lua 來實現,需要注意 redis.call(method, key, field) 的返回值(nil,false,1),此處沒有鍵值返回的是false。如果中間有錯誤,所有的語句不時不生效。

方法三:使用 script_load 和 evalsha

簡而言之,通過 script_load 發送給redis服務器,使加載 lua 腳本,并常駐內存,返回標志,通過 evalsha 按標志進行執行,此連接脫離本次redis 客戶端。

import redis
import time

  r = redis.Redis(host='127.0.0.1', port=31320, password='12345678')
  
  lua = """
  local key = KEYS[1]
  local field = ARGV[1]
  local timestamp_new = ARGV[2]
  
  -- get timestamp of the key in redis
  local timestamp_old = redis.call('hget', key, field)
  -- if timestamp_old == nil, it means the key is not exist
  if timestamp_old == nil or timestamp_old == false or timestamp_new > timestamp_old then
    redis.call('hset', key, field .. 1, timestamp_new)
    -- timestamp_new > timestamp_old
    return redis.pcall('hset', key, field, timestamp_new)
  end
  
  """
  sha = r.script_load(lua)
  print(r.evalsha(sha, 1, 'current', 'time', time.time()))

Redis 管理Lua腳本:(Python下為 script_... )

  • script load

此命令用于將Lua腳本加載到Redis內存中

  • script exists

scripts exists sha1 [sha1 …]  
此命令用于判斷sha1是否已經加載到Redis內存中

  • script flush 

此命令用于清除Redis內存已經加載的所有Lua腳本,在執行script flush后,所有 sha 不復存在。

  • script kill 

此命令用于殺掉正在執行的Lua腳本。

方法四:eval

使用方法與方法三類似,但是eval是一次性請求,每次請求,必須攜帶 lua 腳本

以上就是用python 批量操作redis數據庫的詳細內容,更多關于python 批量操作redis數據庫的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Python3爬蟲RedisDump的安裝步驟
  • Redis分布式鎖python-redis-lock使用方法
  • Python調用Redis的示例代碼
  • Python安裝并操作redis實現流程詳解
  • python操作redis數據庫的三種方法
  • 基于python實現操作redis及消息隊列
  • python3實現將json對象存入Redis以及數據的導入導出
  • Python定時從Mysql提取數據存入Redis的實現
  • Python+redis通過限流保護高并發系統
  • python如何基于redis實現ip代理池

標簽:梅州 懷化 昆明 浙江 石家莊 西寧 錫林郭勒盟 文山

巨人網絡通訊聲明:本文標題《用python 批量操作redis數據庫》,本文關鍵詞  用,python,批量,操作,redis,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《用python 批量操作redis數據庫》相關的同類信息!
  • 本頁收集關于用python 批量操作redis數據庫的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: ?国产精品嫩草影院九色| 攵女yin乱合集高h文| 韩国无码成人??电影| 成**女毛茸茸| 琪琪无码午夜伦埋影院网豆| 成年女性特黄午夜视频免费看| 红桃精品??国产精品 | 偷拍15个女厕AV| 欧美做受???高潮furry| 歪歪视频在线看?免费AV| 欧美激情综合亚洲五月蜜桃| 宝贝帮我拉开拉链它想你了| 和黑人房东在床2在线观看| 99久久国产精品一级毛片| 99久久999久久久综合精品涩| japanbabes日本人奶水| 美欲之母| 国产三级三级三级三级AV精品 | aiai888永久免费视频| 太硬了灬轻点灬嗯嗯大视频| 日本A级毛不卡| 无码av亚洲一区二区毛片公司| 扒下了她湿透的小内裤揉捏| 免费A级作爱片免费看| 欧美大白屁股assvideo| 三级黄色生活片| 波多野在线播放| 杨幂大战老外三分钟四十八秒| 美女入厕偷窥隐私偷藏| 电影来5566黑夜免费播放最新章节| 男女性高爱潮免费网站| 美女作爱视频| 中文一区二区三区| 波多野结衣一道本| 韩国午夜理伦三级在线观看中文版| 他一边吃奶一边摸下面出水了| 草草电影院| 爽?躁多水?快?深点无码| 国产天美麻豆熟妇Av视频| 小东西…快一点重一点| 97在线观看免费|