用idea实现rabbitmq的分列模式demo

什么是分列(Fanout)模式

当我们需要将消息一次发给多个队列时,需要使用这种模式
用idea实现rabbitmq的分列模式demo_第1张图片

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

交换器绑定队列

(1)在queue中添加队列my和ym

(2)新建交换器lmy
进行绑定

代码实现-消息生产者
在test下java下创建生产者


@Test
public void testSendFanout(){
rabbitTemplate.convertAndSend("lmy","", "分列模式走起");
}

代码实现-消息消费者
在src下main下java下创建消费者

创建消息监听类,用于监听my的消息


@Component//放入容器中
@RabbitListener(queues="my" )//指定接收队列的名称
public class Customer2 {
@RabbitHandler
public void showMessage(String message){
System.out.println("my接收到消息:"+message);
}
}

创建消息监听类,用于监听ym的消息


@Component//放入容器中
@RabbitListener(queues="ym" )//指定接收队列的名称
public class Customer3 {
@RabbitHandler
public void showMessage(String message){
System.out.println("ym接收到消息:"+message);
}
}

测试

启动消费者工程,发送消息测试

你可能感兴趣的:(用idea实现rabbitmq的分列模式demo)