Redis / python 实现消息队列的几种方案+步骤

目录

思考角度1:用Python原生数据类型

方法1:Queue类型【先进先出】

思考角度2:用redis,目前有4种方法

方法1:基于List的 L(R) PUSH+L(R)POP 的实现

方法2 :订阅/发布模式,原生的PUB/SUB,频道订阅

方法3:生产消费模式(不推荐)

方法4: 基于Sorted-Set的实现,有序集合,类似于list

 


什么是消息队列??本质就是一个有序列表,有人放,有人拿

思考角度1:用Python原生数据类型

方法1:Queue类型【先进先出】

 1 定义一个队列并初始化长度

2  写一个生产者类,消费者类,都继承线程类Thread,并在类的run()函数里面进行入队列(put),出队列(get)的操作

3 在主函数里面,实例化继承线程类的生产者类 和 消费者类,并start()

# -*- coding:utf-8
import random
from threading import Thread
from queue import Queue
"""基于多线程实现"""

queue = Queue(10)       			 # 1定义一个队列并初始化长度

class Producer(Thread):              # 2写一个生产者,消费者,都继承线程类Thread
	def run(self):
		elem = random.randrange(9)   # 3 生产 消息
		queue.put(elem)              # 4 消息加入队列
		print("生产消息", elem,"已经产了",queue.qsize())

class Consumer(Thread):
	def run(self):
		elem = queue.get()			 # 5 从队列拉取消息
		print("消费", elem,"还有",queue.qsize())

def main():
	for i in range(3):
		p = Producer()
		p.start()

	for i in range(3):
		c = Consumer()
		c.start()

if __name__ == "__main__":
	main()
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Redis、Elasticsearch、MongoDB、消息队列等常见的后端存储和服务,其测试内容和技术都有些差异: 1. Redis 测试: - 功能测试:测试 Redis 的基本数据结构(如字符串、哈希表、列表、集合、有序集合)是否按照预期存储、读取和删除数据。 - 性能测试:测试 Redis 的读写性能、并发性能、容量和稳定性等性能指标。 - 数据一致性测试:测试 Redis 在高并发和复杂场景下的数据一致性,防止数据丢失、重复或不一致等问题。 - 高可用性测试:测试 Redis 的主从复制、哨兵机制、集群和分片等高可用性方案的效果和容错性。 2. Elasticsearch 测试: - 功能测试:测试 Elasticsearch 的索引、搜索、聚合和分析等功能是否按照预期工作。 - 性能测试:测试 Elasticsearch 的读写性能、搜索速度、并发性能和容量等性能指标。 - 数据一致性测试:测试 Elasticsearch 在复杂场景下的数据一致性,防止数据丢失、重复或不一致等问题。 - 高可用性测试:测试 Elasticsearch 的主从复制、分片和集群等高可用性方案的效果和容错性。 3. MongoDB 测试: - 功能测试:测试 MongoDB 的文档存储、查询、更新和删除等功能是否按照预期工作。 - 性能测试:测试 MongoDB 的读写性能、并发性能、容量和稳定性等性能指标。 - 数据一致性测试:测试 MongoDB 在高并发和复杂场景下的数据一致性,防止数据丢失、重复或不一致等问题。 - 高可用性测试:测试 MongoDB 的主从复制、分片和副本集等高可用性方案的效果和容错性。 4. 消息队列测试: - 功能测试:测试消息队列的消息生产、消费、分发和重试等功能是否按照预期工作。 - 性能测试:测试消息队列的吞吐量、响应时间、并发性能和容量等性能指标。 - 数据一致性测试:测试消息队列在高并发和复杂场景下的数据一致性,防止消息丢失、重复或乱序等问题。 - 高可用性测试:测试消息队列的主从复制、集群和分片等高可用性方案的效果和容错性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值