安装库:
pip install pika
发送端,生产者
# 生产者
import pika
# python 链接 RabbitMQ
connection = pika.BlockingConnection(pika.ConnectionParameters('127.0.0.1'))
channel = connection.channel()
# 持久化模式的作用:
# 运行发送端 RabbitMQ 服务正在启动 时发送
# RabbitMQ 服务正在停止后,重新启动
# 接收端 依然可以接受到发送端的信息
# 注意:持久化模式 需要单独指定一个队列,不能与非持久化模式混用一个队列名
# 2 创建队列
channel.queue_declare(queue='Lbw_2',
# durable=True # 持久化模式
)
# 3向指定队列插入数据
# exchange='' 简单模式、 routing_key='hello' 指定队列
channel.basic_publish(exchange='',
routing_key='Lbw_2',
body='SB1',
# properties=pika.BasicProperties(delivery_mode=2) # 持久化模式
)
print("已发送")
接收端,消费者
# 消费者 接收方
import pika
# python 链接 RabbitMQ
connection = pika.BlockingConnection(pika.ConnectionParameters('127.0.0.1'))
channel = connection.channel()
# 2 创建队列
channel.queue_declare(queue='Lbw_2',
# durable=True # 持久化模式
)
# 确定回调函数
def callback(ch, method, properties, body):
print(body)
# 业务逻辑处理。。。。。。
# 手动应答模式
# 处理完成发送给 消息队列 处理完成的信号
ch.basic_ack(delivery_tag=method.delivery_tag)
# 确定 监听队列
channel.basic_consume(queue='Lbw_2',
# 默认应答:快
# auto_ack=True, # 默认应答:收到1个数据,队列中就会少一个数据 如果处理业务逻辑时报错,当前的数据就会丢失
# 手动应答:安全
auto_ack=False, # 手动应答:收到1个数据,等发送处理完毕的信号后,队列中才会少一个数据
on_message_callback=callback)
print(1)
# 多个接收端情况
# 消费者 接收端 默认 轮换接收,
# 你一个,我一个,你一个,我一个.......
# 默认的分发数据机制的存在问题: 若接收端的业务程序消耗时间长短不一,那就会造成阻塞等待.
# 所以采用 公平分发消息机制 哪个接收的快就分发给谁
# 公平分发模式
channel.basic_qos(prefetch_count=1)
# 启动
channel.start_consuming()