RabbitMQ消息分发轮询

简介:

我们首先下载pika,以及rabbitMQ,和ir语言,rabbitMQ是由ir语言编写的

消息队列的使用过程大概如下:

(1)客户端连接到消息队列服务器,打开一个channel。

channel:消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。

(2)客户端声明一个exchange,并设置相关属性。

Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

(3)客户端声明一个queue,并设置相关属性。

Queue:消息队列载体,每个消息都会被投入到一个或多个队列。

(4)客户端使用routing key,在exchange和queue之间建立好绑定关系。

Routing Key:路由关键字,exchange根据这个关键字进行消息投递。

(5)客户端投递消息到exchange。

Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

接下来写一个生产者:

import pika
connection = pika.BlockingConnection(
   pika.ConnectionParameters('localhost'))
channel = connection.channel()#先通过socket建立一个实例,创建一个新的频道

# 声明queue
channel.queue_declare(queue='hello')# 注意此处需要声明一个管道或者称之为队列,在此处出发消息 同时客户端与服务端都需要

# n RabbitMQ a message can never be sent directly to the queue, it always needs to go through an exchange.
channel.basic_publish(exchange='',
                     routing_key='hello',#queue名字#路由键,写明将消息发往哪个队列,本例是将消息发往队列pikamq
                     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('--->',ch,method,properties)
         print(" [x] Received %r"%body)
channel.basic_consume(callback,
                     queue='hello',
                     #no_ack=True  #此处有的代码加了,但是python系统会自带,同时加了之后,一旦等待时间过长,生产者发送的消息,无法转移到另一个消费者中
                     )
channel.start_consuming()



      本文转自眉间雪 51CTO博客,原文链接:http://blog.51cto.com/13348847/1979026,如需转载请自行联系原作者





相关实践学习
RocketMQ一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
7月前
|
消息中间件 存储 Java
RabbitMQ之延迟队列解读
RabbitMQ之延迟队列解读
|
8月前
|
消息中间件 存储 缓存
服务异步通信--RabbitMQ
服务异步通信--RabbitMQ
45 0
|
4月前
|
消息中间件
RabbitMQ 实现消息队列延迟
RabbitMQ 实现消息队列延迟
126 0
|
4月前
|
消息中间件 Shell 数据库
RabbitMQ之延迟消息
RabbitMQ之延迟消息
|
10月前
|
消息中间件 Java 中间件
rabbitmq简单队列
rabbitmq简单队列
|
6月前
|
消息中间件 缓存 网络协议
RabbitMQ消息确认
RabbitMQ消息确认
|
9月前
|
消息中间件
RabbitMq消息确认机制
RabbitMq消息确认机制
59 0
|
10月前
|
消息中间件 存储 调度
RabbitMQ的延迟队列
RabbitMQ的延迟队列是一种特殊的队列,可以在消息发送后延迟一段时间后再将消息投递给消费者。
151 0
|
10月前
|
消息中间件 存储 中间件
RabbitMQ的延迟队列
RabbitMQ是一个开源的消息队列中间件,它提供了可靠的消息传递机制,被广泛应用于分布式系统中。延迟队列是RabbitMQ中常用的一种队列类型,它可以用来实现消息的延时投递。
187 0
|
12月前
|
消息中间件 Java
RabbitMQ发送方确认机制
RabbitMQ发送方确认机制
75 0