上一篇中我们构建了一个简单的日志系统,我们可以把日志消息广播给多个接受者。
这篇中我们将来添加一个特性只接收部分消息。例如我只将一些错误log存到文件中,把所有的log都打印到控制台里。
1、绑定(Bindings)
在上篇中,我们已经创建了一个binding,代码如下:
channel.queueBind(queueName, EXCHANGE_NAME, "");
一个binding就是exchange和Queue之间的一个关系。可以简单的理解为:这个Queue对其相对于的exchange的消息感兴趣(原文是the queue is interested in messages from this exchange)。
Binding可以使用一个已经存在的routingKey参数。为了避免和basic_publish参数混淆,我们称之为binding key。下边就是我们怎么用key来创建一个binding:
channel.queueBind(queueName, EXCHANGE_NAME, "black");
binding key的意义有时候取决于exchange的类型。对于Fanout类型的exchange,会忽略binding key。
2、Direct类型的exchange
上篇中的日志系统会把所有的log消息广播给所有的消费者。我们想扩展来根据他们的日志级别来过滤log消息。例如:我们只想把error级别的日志写到磁盘文件中,而其它级别的日志消息则过滤掉。
我们之前使用的fanout类型的exchange,但这样就不会有太多的灵活