实际上这种模式就是一种模糊匹配的模式,我们可以将routingKey以模糊匹配的方式去进行转发。

我们可以使用*或#来表示:
这里我们来测试一下:
- @Configuration
- public class RabbitConfiguration {
-
- @Bean("topicExchange") //这里使用预置的Topic类型交换机
- public Exchange exchange(){
- return ExchangeBuilder.topicExchange("amq.topic").build();
- }
-
- @Bean("yydsQueue")
- public Queue queue(){
- return QueueBuilder.nonDurable("yyds").build();
- }
-
- @Bean("binding")
- public Binding binding2(@Qualifier("topicExchange") Exchange exchange,
- @Qualifier("yydsQueue") Queue queue){
- return BindingBuilder
- .bind(queue)
- .to(exchange)
- .with("*.test.*")
- .noargs();
- }
- }
启动项目,可以看到只要是满足通配符条件的都可以成功转发到对应的消息队列:

接着我们可以再试试看#通配符。
除了我们这里使用的默认主题交换机之外,还有一个叫做amq.rabbitmq.trace的交换机:

可以看到它也是topic类型的,那么这个交换机是做什么的呢?实际上这是用于帮助我们记录和追踪生产者和消费者使用消息队列的交换机,它是一个内部的交换机,那么如果使用呢?首先创建一个消息队列用于接收记录:

接着我们需要在控制台将虚拟主机/test的追踪功能开启:
sudo rabbitmqctl trace_on -p /test
开启后,我们将此队列绑定到上面的交换机上:


由于发送到此交换机上的routingKey为routing key为 publish.交换机名称 和 deliver.队列名称,分别对应生产者投递到交换机的消息,和消费者从队列上获取的消息,因此这里使用#通配符进行绑定。
现在我们来测试一下,比如还是往yyds队列发送消息:

可以看到在发送消息,并且消费者已经处理之后,trace队列中新增了两条消息,那么我们来看看都是些什么消息:

通过追踪,我们可以很明确地得知消息发送的交换机、routingKey、用户等信息,包括信息本身,同样的,消费者在取出数据时也有记录:

我们可以明确消费者的地址、端口、具体操作的队列以及取出的消息信息等。
到这里,我们就已经了解了3种类型的交换机。