真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

利用Redis流怎么實現(xiàn)一個消息隊列-創(chuàng)新互聯(lián)

利用Redis流怎么實現(xiàn)一個消息隊列?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

在無錫等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計制作、網(wǎng)站設(shè)計 網(wǎng)站設(shè)計制作按需策劃設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,成都營銷網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè)公司,無錫網(wǎng)站建設(shè)費用合理。

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

  • 代碼最開頭的是幾個轉(zhuǎn)換函數(shù), 它們負(fù)責(zé)對程序的相關(guān)輸入輸出進(jìn)行轉(zhuǎn)換和格式化;

  • MessageQueue 類用于實現(xiàn)消息隊列, 它的添加消息、移除消息以及返回消息數(shù)量三個方法分別使用了流的 XADD 命令、 XDEL 命令和 XLEN 命令;

  • 消息隊列的兩個獲取方法 get_message() 和 get_by_range() 分別以兩種形式調(diào)用了流的 XRANGE 命令;

  • 最后, 用于迭代消息的 iterate() 方法使用了 XREAD 命令對流進(jìn)行迭代。

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

def reconstruct_message_list(message_list):
  """
  為了讓多條消息能夠以更結(jié)構(gòu)化的方式返回給調(diào)用者,
  將 Redis 返回的多條消息從原來的格式:
  [(id1, {k1:v1, k2:v2, ...}), (id2, {k1:v1, k2:v2, ...}), ...]
  轉(zhuǎn)換成以下格式:
  [{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 流實現(xiàn)的消息隊列。
  """
  def __init__(self, client, stream_key):
    self.client = client
    self.stream = stream_key
  def add_message(self, key_value_pairs):
    """
    將給定的鍵值對存入到消息里面,并返回相應(yīng)的消息 ID 。
    """
    return self.client.xadd(self.stream, key_value_pairs)
  def get_message(self, message_id):
    """
    根據(jù)給定的消息 ID 返回相應(yīng)的消息,如果消息不存在則返回 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):
    """
    根據(jù)給定的消息 ID 刪除相應(yīng)的消息,如果消息不存在則忽略該動作。
    """
    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):
    """
    根據(jù)給定的 ID 區(qū)間范圍返回隊列中的消息。
    """
    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):
    """
    對消息隊列進(jìn)行迭代,返回最多 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)

對于這個消息隊列實現(xiàn), 我們可以通過執(zhí)行以下代碼, 創(chuàng)建出它的實例:

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

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

>>> 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'

還可以根據(jù) 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() 方法對消息隊列進(jìn)行迭代, 等等:

>>> 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'}}]

看完上述內(nèi)容,你們掌握利用Redis流怎么實現(xiàn)一個消息隊列的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


本文題目:利用Redis流怎么實現(xiàn)一個消息隊列-創(chuàng)新互聯(lián)
鏈接地址:http://weahome.cn/article/jcjgc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部