参考http://blog.csdn.net/lmj623565791/article/details/37620057和RabbitMQ官网,加之自己部分修改和实验,因是新手自学,难免有不对之处,欢迎大家指正,小弟先谢过了.
在上一篇文章中,我们学习了关于RabbitMQ工作队列,了解其分发消息的一些方式和消息反馈机制等等,并且假定一个任务只给一个消费者,但是在实际工作中”一对一”模式显然是满足不了需求的,在这篇文章里,我们将来实验一些尽量和实际相关度较高的例子——将一个任务发给所有消费者,然后消费者决定如何处理这些消息.
现在开始今天的第一个概念: exchange (转发器/路由器)
先摘录一段官网的话
The core idea in the messaging model in RabbitMQ is that the producer never sends any messages directly to a queue. Actually, quite often the producer doesn’t even know if a message will be delivered to any queue at all.
Instead, the producer can only send messages to an exchange. An exchange is a very simple thing. On one side it receives messages from producers and the other side it pushes them to queues. The exchange must know exactly what to do with a message it receives. Should it be appended to a particular queue? Should it be appended to many queues? Or should it get discarded. The rules for that are defined by the exchange type.
大概翻译一下:在RabbitMQ的消息模式设计中最核心的理念就是producer永远都不直接发送任何消息给队列,实际上大部分时候,producer甚至都不知道消息将会被传递到哪个队列.相反,producer只是将消息发送给exchange(转换器/路由器).其实exchange说起来只是做了一个简单的工作:
1.接收从producer发来的消息
2.把接收到的消息push给队列
有这样的工作特点,说明exchange必须清楚的知道该对它接到的消息做怎杨的处理: 是不是该把消息发送到一个特定的队列? 还是发送到很多的队列? 还是直接忽略掉? 到底该如何做,取决于你如何定义exchange的类型.
exchage类型:
1. direct
2. topic
3. headers
4. fanout
说到这,细心的同学肯定发现了,之前的例子中并没有去声明一个e