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退出。