RabbitMQ中,所有生产者提交的消息都由Exchange来接受,然后Exchange按照特定的策略转发到Queue进行存储

RabbitMQ提供了四种Exchange:fanout, direct, topic, header
header模式在实际使用中较少,本文只对前三种模式进行比较。
性能排序:fanout
> direct >> topic

。比例大约为11:10:6



六、关键字发送

exchange type = direct

之前事例,发送消息时明确指定某个队列并向其中发送消息,RabbitMQ还支持根据关键字发送,即:队列绑定关键字,发送者将数据根据关键字发送到消息exchange,exchange根据 关键字 判定应该将数据发送至指定队列。

1.生产者:


import pika
import sys

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

channel.exchange_declare(exchange='direct_logs',
type='direct')

result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue

severities = sys.argv[1:]
if not severities:
sys.stderr.write("Usage: %s [info] [warning] [error]\n" % sys.argv[0])
sys.exit(1)

for severity in severities:
channel.queue_bind(exchange='direct_logs',
queue=queue_name,
routing_key=severity)

print(' [*] Waiting for logs. To exit press CTRL+C')

def callback(ch, method, properties, body):
print(" [x] %r:%r" % (method.routing_key, body))

channel.basic_consume(callback,
queue=queue_name,
no_ack=True)

channel.start_consuming()

2、消费者


import pika
import sys

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

channel.exchange_declare(exchange='direct_logs',
type='direct')

severity = sys.argv[1] if len(sys.argv) > 1 else 'info'
message = ' '.join(sys.argv[2:]) or 'Hello World!'
channel.basic_publish(exchange='direct_logs',
routing_key=severity,
body=message)
print(" [x] Sent %r:%r" % (severity, message))
connection.close()


一、Direct Exchange

任何发送到Direct
Exchange的消息都会被转发到RouteKey中指定的Queue。

1.一般情况可以使用rabbitMQ自带的Exchange:”"(该Exchange的名字为空字符串,下文称其为default
Exchange)。
2.这种模式下不需要将Exchange进行任何绑定(binding)操作
3.消息传递时需要一个“RouteKey”,可以简单的理解为要发送到的队列名字。
4.如果vhost中不存在RouteKey中指定的队列名,则该消息会被抛弃。

二、Fanout Exchange 

任何发送到Fanout
Exchange的消息都会被转发到与该Exchange绑定(Binding)的所有Queue上。

1.可以理解为路由表的模式
2.这种模式不需要RouteKey
3.这种模式需要提前将Exchange与Queue进行绑定,一个Exchange可以绑定多个Queue,一个Queue可以同多个Exchange进行绑定。
4.如果接受到消息的Exchange没有与任何Queue绑定,则消息会被抛弃。

三、Topic Exchange

任何发送到Topic
Exchange的消息都会被转发到所有关心RouteKey中指定话题的Queue上

1.这种模式较为复杂,简单来说,就是每个队列都有其关心的主题,所有的消息都带有一个“标题”(RouteKey),Exchange会将消息转发到所有关注主题能与RouteKey模糊匹配的队列。
2.这种模式需要RouteKey,也许要提前绑定Exchange与Queue。
3.在进行绑定时,要提供一个该队列关心的主题,如“#.log.#”表示该队列关心所有涉及log的消息(一个RouteKey为”MQ.log.error”的消息会被转发到该队列)。
4.“#”表示0个或若干个关键字,“*”表示一个关键字。如“log.*”能与“log.warn”匹配,无法与“log.warn.timeout”匹配;但是“log.#”能与上述两者匹配。
5.同样,如果Exchange没有发现能够与RouteKey匹配的Queue,则会抛弃此消息

最新文章

  1. Repeater的Item项绑定DropDownList
  2. 基础才是重中之重~stream和byte[]的概念与转化
  3. QT学习笔记4
  4. open-flash-chart2
  5. [Cocos2d-x For WP8]矩形碰撞检测
  6. PHP生成 excl、word文件
  7. 为SM30视图分配事务代码
  8. ZZTHX-线程锁
  9. iOS不越狱装收费App——注册iOS设备为开发者工具
  10. [转] Python正则表达式指南
  11. 汇编笔记之 ret 、retf和call
  12. 多线程 AfxBeginThread 与 CreateThread 的区别
  13. C++程序员的阅读清单
  14. ActiveMQ 503错误
  15. 手机端仿ios的省市县3级联动脚本一
  16. mac下安装redis详细步骤
  17. Python杀死windows进程
  18. C++ code:位操作实例(bit operation example)
  19. MySql与MariaDB由来与历程
  20. linux 将一个文件分解成多个不同名文件

热门文章

  1. 错题0920-java
  2. Linux心得记录
  3. hdu 3085(双向bfs)
  4. LINQ to SQL语句(2)Count/Sum/Min/Max/Avg操作符
  5. web版pdf在线阅读器
  6. 第十六篇:Linux系统编程中环境变量的使用
  7. std::unique_lock
  8. 【BZOJ4563】[Haoi2016]放棋子 错排+高精度
  9. Max_connect_errors – MySQL性能参数详解
  10. vue兄弟组件传值