在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

利用Redis流怎么实现一个消息队列

111次阅读
没有评论

共计 2941 个字符,预计需要花费 8 分钟才能阅读完成。

自动写代码机器人,免费开通

利用 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 流怎么实现一个消息队列的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计2941字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 久久人妻av一区二区软件 | 久久国产精品99久久小说 | 精品成人一区二区三区免费视频 | 尤物视频网站在线观看 | 丝袜人妻一区二区三区网站 | 国模无水印一区二区三区 | 91视频第一页 | 精品国产乱码久久久久久一区二区 | 欧美精品亚洲精品日韩专 | 人妻无码中文专区久久五月婷 | 色琪琪av中文字幕一区二区 | 色菇凉天天综合网 | 性一交一乱一伦一 | 国产精品成人99一区无码 | 九九国产在线视频 | 欧美日韩国产一区二区 | 国产肉体xxxx裸体784大胆 | 亚洲av午夜成人片 | 人也色| 亚洲精品一区久久狠狠欧美 | 亚洲成本人网亚洲视频大全 | 夜夜爽爽 | 成年人黄视频在线观看 | 九九精品视频一区二区三区 | 一区二区三区精品视频 | 精品国产成人亚洲午夜福利 | 国产真实露脸乱子伦 | 国产一级毛片国产 | 免费观看成年人视频 | 99精品视频在线免费观看 | 丝袜美腿精品一区二区三 | 无码综合天天久久综合网 | 黄污视频免费 | 国产 校园 另类 小说区 | 久久99精品久久久久久水蜜桃 | 人人鲁人人莫人人爱精品 | 在线精品国产一区二区 | 国产精品成人不卡在线观看 | 久久亚洲av成人无码国产 | 国语自产精品视频在线看 | 午夜小说网 |