RabbitMQ - 1消息队列中间件AMQP协议、和主要角色
RabbitMQ是一个开源的消息队列中间件,实现了AMQP(高级消息队列协议)。它支持多种客户端,并能够以集群的方式运行,以满足高级消息中间件的需求。
AMQP协议是一个定义了消息路由规则的开放标准,它通过提供一种方法来保证消息从生产者到消费者的传递,并保证消息的发送和接收过程的解耦。
RabbitMQ的主要角色包括:
- 生产者(Producer):发送消息到队列的应用。
- 消费者(Consumer):从队列接收消息的应用。
- 队列(Queue):存储消息的缓冲区,消费者从队列中取得消息。
- 交换器(Exchange):用来接收生产者发送的消息,并根据不同的路由算法将这些消息路由到一个或多个队列。
- 绑定(Binding):将交换器和队列连接起来的规则。
- 路由键(Routing Key):生产者将消息发送给交换器时,会指定一个路由键,用于指导消息如何路由。
- 虚拟主机(Virtual Host):提供隔离的消息队列集合,每个用户都可以创建自己的虚拟主机。
- 连接(Connection):对于RabbitMQ,客户端与服务器之间的TCP连接。
- 信道(Channel):建立在真实的TCP连接内的虚拟连接,RabbitMQ通过使用信道来发送和接收消息。
RabbitMQ的安装和基本使用可以参考以下步骤:
安装RabbitMQ:
# Ubuntu/Debian
sudo apt-get install rabbitmq-server
# CentOS/RHEL
sudo yum install rabbitmq-server
# macOS
brew install rabbitmq
启动RabbitMQ服务:
# Ubuntu/Debian
sudo service rabbitmq-server start
# CentOS/RHEL
sudo systemctl start rabbitmq-server
# macOS
brew services start rabbitmq
基本的生产者和消费者代码示例(以Python为例):
生产者(发送消息):
import pika
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()
消费者(接收消息):
import pika
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.queue_declare(queue='hello')
def callback(ch, method, properties, body):
print(f" [x] Received {body}")
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中创建一个队列,发送和接收消息的基本步骤。
评论已关闭