RabbitMQ的基本概念和入门

RabbitMQ是一个开源的消息代理和队列服务器,用于通过整个企业和应用程序之间发送消息。以下是RabbitMQ的基本概念和入门示例:

1.队列(Queue):RabbitMQ内部使用队列来存储消息。队列是消息的容器,消息在发送给客户端之前会在队列中等待。

2.生产者(Producer):发送消息到队列的应用程序称为生产者。

3.消费者(Consumer):从队列中获取消息的应用程序称为消费者。

4.交换器(Exchange):生产者将消息发送到交换器,交换器根据路由键(Routing Key)将消息路由到一个或多个队列。

安装RabbitMQ:

Ubuntu/Debian

sudo apt-get install rabbitmq-server

CentOS

sudo yum install rabbitmq-server

macOS (使用Homebrew)

brew install rabbitmq

Python 使用 pika 库连接和使用 RabbitMQ:

import pika

连接到RabbitMQ服务器

connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))

channel = connection.channel()

声明一个队列

channel.queue_declare(queue='hello')

def callback(ch, method, properties, body):

print(f"Received {body.decode()}")

定义一个消费者,从队列中接收消息

channel.basic_consume(queue='hello', on_message_callback=callback, auto_ack=True)

print('Waiting for messages. To exit press CTRL+C')

channel.start_consuming()

在上面的例子中,我们首先连接到RabbitMQ服务器,声明了一个名为'hello'的队列,然后定义了一个回调函数来处理接收到的消息。最后,我们开始消费消息,等待用户按下CTRL+C退出。

相关推荐
百锦再3 分钟前
大型省级政务平台采用金仓数据库(KingbaseES)
开发语言·数据库·后端·rust·eclipse
m0_6398171515 分钟前
基于springboot个人云盘管理系统【带源码和文档】
java·spring boot·后端
biter down20 分钟前
C 语言17:位操作符 & | ^:从二进制编码到大小端
c语言·开发语言
mjhcsp24 分钟前
C++ map 容器:有序关联容器的深度解析与实战
开发语言·c++·map
将编程培养成爱好27 分钟前
C++ 设计模式《账本事故:当备份被删光那天》
开发语言·c++·设计模式·备忘录模式
黑咩狗夜.cm34 分钟前
Aspose.word实现表格每页固定表头、最后一行填满整个页面
开发语言·c#·word
NUllPOINTEXCEPTION1 小时前
MyBatis-Plus 开发指北
后端
饼干,1 小时前
第5天python内容
开发语言·python
froginwe111 小时前
Ruby 发送邮件 - SMTP
开发语言
bcbnb1 小时前
没有 Mac,如何上架 iOS App?跨平台开发者的完整上架实战指南
后端