Python RabbitMQ 入门 pika

Python RabbitMQ 入门

RabbitMQ 是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。

首先要安装运行 RabbitMQ 服务, (RabbitMQ 依赖于 Erlang 环境, 所以还要装 Erlang), Erlang与RabbitMQ,安装路径都应不含空格符

下载地址: Installing RabbitMQ | RabbitMQ

安装

复制代码
pip install pika

消费者 consumer.py

py 复制代码
import pika

# 创建一个连接
credentials = pika.PlainCredentials('guest', 'guest')
parameters = pika.ConnectionParameters('localhost',
                                       5672,
                                       '/',
                                       credentials)

connection = pika.BlockingConnection(parameters)
channel = connection.channel()
# 声明一个队列, durable=True表示队列持久化
channel.queue_declare(queue='hello', durable=True)


def callback(ch, method, properties, body):
    print("Received message:", body)


channel.basic_consume(queue='hello',  # 指定消费的队列
                      auto_ack=True,  # 自动确认消息
                      on_message_callback=callback)

# 当我们启动消费者时,我们就开启了一个永远不会停止的循环,消费者等待数据并调用回调函数,我们通过捕获KeyboardInterrupt来停止程序
print("Waiting for messages. To exit press CTRL+C")
channel.start_consuming()

生产者 producer.py

py 复制代码
import time

import pika

# 创建一个连接
credentials = pika.PlainCredentials('guest', 'guest')
parameters = pika.ConnectionParameters('localhost',
                                       5672,
                                       '/',
                                       credentials)
connection = pika.BlockingConnection(parameters)
# 创建一个频道
channel = connection.channel()
# 消费者那里已经声明了队列,这里不需要再重复声明
# channel.queue_declare(queue='hello', durable=True)

# 在RabbitMQ中,消息不能直接发送到队列,通常需要需要一个exchange, 这里使用默认的exchange
# exchange用来准确指定我们的消息撒送到哪个queue,queue的名称需要在routing_key中声明
for i in range(100):
    # 发布消息
    channel.basic_publish(exchange='',
                          routing_key='hello',
                          body=f'{i} Hello World!')
    print(f" [x] Sent {i} Hello World!")
    time.sleep(.5)
# 关闭连接
connection.close()

运行结果

GUI管理工具:

RabbitMQ Assistant - RabbitMQ可视化管理与监控工具 (redisant.cn)

启动服务后, 访问 http://localhost:15672/# 也有GUI界面

参考:

相关推荐
超梦dasgg7 分钟前
Java 生产环境 MQ 技术选型全解析
java·开发语言·java-rocketmq·java-rabbitmq
桀人43 分钟前
C++——模板初阶(收录在专栏C++入门到精通)
开发语言·c++
一直有一个ac的梦想1 小时前
cmu15445 2025fall lec 18 transactions with two-phase lock
java·开发语言·数据库
毋语天1 小时前
FastAPI 进阶实战:请求体、文件上传、响应模型与数据校验
python·fastapi·api开发·数据校验·pydantic
JAVA社区1 小时前
Java进阶全套教程(四)—— SpringMVC框架详解
java·开发语言·spring·面试·职场和发展
Lumbrologist1 小时前
【C++】零基础入门 · 第 2 节:变量、基本数据类型与输入输出
java·开发语言·c++
码完就睡1 小时前
C语言——动态内存
c语言·开发语言
xyq20242 小时前
Java 数组
开发语言
雨辰AI2 小时前
人大金仓 V9 生产级专用监控大盘(含 120 + 指标 + 告警规则 + 一键导入)
java·开发语言·数据库·mysql·政务
时寒的笔记2 小时前
day13~14核心案例某采招网
开发语言·javascript·ecmascript