python 使用rabbitmq

在使用Python与RabbitMQ进行消息队列通信时,你可以使用pika库,这是RabbitMQ的官方Python客户端。以下是如何使用pika库来发送和接收消息的基本步骤。

安装pika

首先,你需要安装pika库。你可以通过pip来安装:

css 复制代码
pip install pika

发送消息

要发送消息,你需要连接到RabbitMQ服务器,创建一个channel,然后声明一个队列,并发送消息。

css 复制代码
import pika
 
# 连接到RabbitMQ服务器
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
 
# 声明一个队列,如果队列不存在将会自动创建
channel.queue_declare(queue='hello')
 
# 发送一个消息到队列
channel.basic_publish(exchange='',
                     routing_key='hello',
                     body='Hello World!')
print(" [x] Sent 'Hello World!'")
 
# 关闭连接
connection.close()

接收消息

要接收消息,你需要连接到RabbitMQ服务器,创建一个channel,声明一个队列,并订阅该队列以接收消息。

css 复制代码
import pika
 
def callback(ch, method, properties, body):
    print(f" [x] Received {body}")
 
# 连接到RabbitMQ服务器
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
 
# 声明一个队列,如果队列不存在将会自动创建
channel.queue_declare(queue='hello')
 
# 订阅队列以接收消息
channel.basic_consume(queue='hello', on_message_callback=callback, auto_ack=True)
 
print(' [*] Waiting for messages. To exit press CTRL+C')
channel.start_consuming()

注意事项:

连接参数:在pika.ConnectionParameters中,你可以指定主机名(默认为localhost)、端口号(默认为5672)、用户名和密码等。例如:pika.ConnectionParameters(host='your_host', port=5672, credentials=pika.PlainCredentials('username', 'password'))。

错误处理:在实际应用中,你可能需要添加错误处理逻辑,例如重试连接、处理网络中断等。

自动应答:在basic_consume中设置auto_ack=True表示自动应答。如果你需要手动应答(例如,只有在处理完消息后才确认),可以设置为auto_ack=False并在处理完消息后调用ch.basic_ack(delivery_tag)。

交换器(Exchange):上面的示例中使用了默认的交换器(空字符串''),这意味着消息将直接发送到指定的队列。RabbitMQ支持多种类型的交换器,如direct, topic, fanout, 和 headers。你可以根据需要选择或创建不同类型的交换器。例如,使用direct交换器:

css 复制代码
channel.exchange_declare(exchange='my_exchange', exchange_type='direct')
channel.basic_publish(exchange='my_exchange', routing_key='hello', body='Hello World!')

接收方也需要声明相同的交换器和队列绑定规则。

通过以上步骤,你可以使用Python和pika库与RabbitMQ进行基本的消息发送和接收操作。

相关推荐
yzx99101311 分钟前
Python开发系统项目
人工智能·python·深度学习·django
FreakStudio1 小时前
一文速通 Python 并行计算:12 Python 多进程编程-进程池 Pool
python·嵌入式·面向对象·多进程·并行计算·电子diy
计算机毕设定制辅导-无忧学长2 小时前
RabbitMQ 监控与调优实战指南(二)
分布式·rabbitmq·ruby
天才测试猿2 小时前
接口自动化测试之pytest接口关联框架封装
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·pytest
先做个垃圾出来………2 小时前
Python中使用pandas
开发语言·python·pandas
不爱吃山楂罐头3 小时前
第三十三天打卡复习
python·深度学习
Dxy12393102164 小时前
DrissionPage 性能优化实战指南:让网页自动化效率飞升
运维·爬虫·python·性能优化·自动化
蹦蹦跳跳真可爱5894 小时前
Python----目标检测(《SSD: Single Shot MultiBox Detector》论文和SSD的原理与网络结构)
人工智能·python·深度学习·神经网络·目标检测·计算机视觉
LeonDL1684 小时前
HALCON 深度学习训练 3D 图像的几种方式优缺点
人工智能·python·深度学习·3d·halcon·halcon训练3d图像·深度学习训练3d图像
smileNicky5 小时前
SpringBoot系列之RabbitMQ 实现订单超时未支付自动关闭功能
spring boot·rabbitmq·java-rabbitmq