RabbitMQ 简单模式 python接口

本文介绍了如何使用 Python 的 pika 库连接并配置 RabbitMQ,实现消息的持久化发送与接收。通过设置 durable 参数确保消息在服务重启后仍可被消费。同时,展示了基本的生产者和消费者模型,以及手动应答模式以确保消息正确处理。此外,还提到了公平分发消息的策略,以优化多消费者环境下的消息处理效率。
摘要由CSDN通过智能技术生成

安装库:

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()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

默执_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值