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

主頁 > 知識庫 > 使用 Redis 流實現消息隊列的代碼

使用 Redis 流實現消息隊列的代碼

熱門標簽:一個地圖標注多少錢 廊坊外呼系統在哪買 南京手機外呼系統廠家 b2b外呼系統 高碑店市地圖標注app 臺灣電銷 400電話辦理的口碑 四川穩定外呼系統軟件 地圖標注工廠入駐

在介紹了 Redis 流的基本功能之后, 現在是時候使用這些功能來構建一些實際的應用了。 消息隊列作為流的典型應用之一, 具有非常好的示范性, 因此我們將使用 Redis 流的相關功能構建一個消息隊列應用, 這個消息隊列跟我們之前使用其他 Redis 數據結構構建的消息隊列具有相似的功能。

代碼清單 10-1 展示了一個具有基本功能的消息隊列實現:

  • 代碼最開頭的是幾個轉換函數, 它們負責對程序的相關輸入輸出進行轉換和格式化;
  • MessageQueue 類用于實現消息隊列, 它的添加消息、移除消息以及返回消息數量三個方法分別使用了流的 XADD 命令、 XDEL 命令和 XLEN 命令;
  • 消息隊列的兩個獲取方法 get_message() 和 get_by_range() 分別以兩種形式調用了流的 XRANGE 命令;
  • 最后, 用于迭代消息的 iterate() 方法使用了 XREAD 命令對流進行迭代。

代碼清單 10-1 使用 Redis 流實現的消息隊列: /stream/message_queue.py

def reconstruct_message_list(message_list):
  """
  為了讓多條消息能夠以更結構化的方式返回給調用者,
  將 Redis 返回的多條消息從原來的格式:
  [(id1, {k1:v1, k2:v2, ...}), (id2, {k1:v1, k2:v2, ...}), ...]
  轉換成以下格式:
  [{id1: {k1:v1, k2:v2, ...}}, {id2: {k1:v1, k2:v2, ...}}, ...]
  """  result = []
  for id, kvs in message_list:
    result.append({id: kvs})
  return result
def get_message_from_nested_list(lst):
  """
  從嵌套列表中取出消息本體。
  """
  return lst[0][1]
class MessageQueue:
  """
  使用 Redis 流實現的消息隊列。
  """
  def __init__(self, client, stream_key):
    self.client = client
    self.stream = stream_key
  def add_message(self, key_value_pairs):
    """
    將給定的鍵值對存入到消息里面,并返回相應的消息 ID 。
    """
    return self.client.xadd(self.stream, key_value_pairs)
  def get_message(self, message_id):
    """
    根據給定的消息 ID 返回相應的消息,如果消息不存在則返回 None 。
    """
    reply = self.client.xrange(self.stream, message_id, message_id)
    if len(reply) == 1:
      return get_message_from_nested_list(reply)

  def remove_message(self, message_id):
    """
    根據給定的消息 ID 刪除相應的消息,如果消息不存在則忽略該動作。
    """
    self.client.xdel(self.stream, message_id)

  def len(self):
    """
    返回消息隊列的長度。
    """
    return self.client.xlen(self.stream)

  def get_by_range(self, start_id, end_id, max_item=10):
    """
    根據給定的 ID 區間范圍返回隊列中的消息。
    """
    reply = self.client.xrange(self.stream, start_id, end_id, max_item)
    return reconstruct_message_list(reply)

  def iterate(self, start_id=0, max_item=10):
    """
    對消息隊列進行迭代,返回最多 N 條大于給定 ID 的消息。
    """
    reply = self.client.xread({self.stream: start_id}, max_item)
    if len(reply) == 0:
      return list()
    else:
      messages = get_message_from_nested_list(reply)
      return reconstruct_message_list(messages)

對于這個消息隊列實現, 我們可以通過執行以下代碼, 創建出它的實例:

>>> from redis import Redis
>>> from message_queue import MessageQueue
>>> client = Redis(decode_responses=True)
>>> mq = MessageQueue(client, "mq")

然后通過執行以下代碼, 向隊列里面添加十條消息:

>>> for i in range(10):
...  key = "key{0}".format(i)
...  value = "value{0}".format(i)
...  msg = {key:value}
...  mq.add_message(msg)
...
'1554113926280-0'
'1554113926280-1'
'1554113926281-0'
'1554113926281-1'
'1554113926281-2'
'1554113926281-3'
'1554113926281-4'
'1554113926281-5'
'1554113926281-6'
'1554113926282-0'

還可以根據 ID 獲取指定的消息, 又或者使用 get_by_range() 方法同時獲取多條消息:

>>> mq.get_message('1554113926280-0')
{'key0': 'value0'}
>>> mq.get_message('1554113926280-1')
{'key1': 'value1'}
>>> mq.get_by_range("-", "+", 3)
[{'1554113926280-0': {'key0': 'value0'}}, {'1554113926280-1': {'key1': 'value1'}}, {'1554113926281-0': {'key2': 'value2'}}]

又或者使用 iterate() 方法對消息隊列進行迭代, 等等:

>>> mq.iterate(0, 3)
[{'1554113926280-0': {'key0': 'value0'}}, {'1554113926280-1': {'key1': 'value1'}}, {'1554113926281-0': {'key2': 'value2'}}]
>>> mq.iterate('1554113926281-0', 3)
[{'1554113926281-1': {'key3': 'value3'}}, {'1554113926281-2': {'key4': 'value4'}}, {'1554113926281-3': {'key5': 'value5'}}]

總結

以上所述是小編給大家介紹的使用 Redis 流實現消息隊列的代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

您可能感興趣的文章:
  • php+redis消息隊列實現搶購功能
  • Java利用Redis實現消息隊列的示例代碼
  • PHP基于Redis消息隊列實現發布微博的方法
  • phpredis提高消息隊列的實時性方法(推薦)
  • 詳解Redis用鏈表實現消息隊列
  • PHP使用php-resque庫配合Redis實現MQ消息隊列的教程

標簽:南寧 泰州 甘南 定州 伊春 拉薩 河源 畢節

巨人網絡通訊聲明:本文標題《使用 Redis 流實現消息隊列的代碼》,本文關鍵詞  使用,Redis,流,實現,消息,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用 Redis 流實現消息隊列的代碼》相關的同類信息!
  • 本頁收集關于使用 Redis 流實現消息隊列的代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 在线免费看a| 欧美性猛交乱大交XXXXⅩOOO | 夜夜躁爽日日躁狠狠躁视频| 国产蜜桃tv一区| 色综合久久综合| 白丝护士美女被躁翻了网站| 韩国黄色录像| 两个白屁股并排撅着| 91精品国产福利尤物免费| 老师在办公室疯狂的肉| 亚洲AV片一区二区三区紫牛| 国产?无码?免费视频| 色情大尺度吃奶做爰电影| 狠狠色丁香婷婷久久综合不卡| 男人秘?桶进美女屁股的软件| 欧美三级a| 欧美成人做爰高潮片免费看夜魔| 强行扒开双腿猛烈进入电影| 亚洲色自拍自偷另类在线| 韩国理伦片巜隔壁的小伙子2| 欧美jiZZHD精品欧美18| 老师穿旗袍白丝任我爽撞| 爽?躁多水?快?深点无码| 91麻豆极品在线观看| 第102章 浴室缠欢| Wc女厕偷拍在线视频| 秋霞精品| 美女扒开内裤羞羞?网站| 台中县| 久久夜色tv网站免费影院| 极品美女XXXXHD| 内衣办公室在线播放| 欧美午夜精品理论片A级| 性谜宫| 男人桶女人屁股桶爽30分钟免费| 狠狠躁夜夜躁人人爽碰97香蕉| 手机看黄色片| 久草app下载| 久精品国产欧美亚洲色aⅴ大片| 国产成人在线播放| 日本理论片www视频|