1.Topic模式
RabbitMQ的Topic模式是一种基于主题的消息传递模式。它允许发送者向一个特定的主题(topic)发布消息,同时,订阅者也可以针对自己感兴趣的主题进行订阅。
在Topic模式中, 主题通过一个由单词和点号组成的字符串来描述。例如,“#.china”表示匹配所有以“china”为结尾的主题,比如“bj.china”或“china”等。( ‘ # ’ 和 ‘ * ’ 会再后面介绍)
当一个消息被发布到Topic交换机(Exchange)时,交换机会将消息转发给所有与该主题匹配的队列。消费者(即订阅者)可以对队列进行绑定,通过指定自己感兴趣的主题进行绑定。
通过使用Topic模式,我们可以实现高度灵活的信息交换模式,同时,确保只有感兴趣的消费者才会收到消息,提高了系统的效率和可靠性。
- *匹配1个
- #匹配0个或多个
- 当一个队列绑定键是#,那么这个队列将接收所有数据,就有点像 fanout 了
- 如果队列绑定键当中没有#和*出现,那么该队列绑定类型就是 direct 了
2. 生产者
packagecom.hong.rabbitmq8;importcom.hong.utils.RabbitMQUtil;importcom.rabbitmq.client.BuiltinExchangeType;importcom.rabbitmq.client.Channel;importjava.nio.charset.StandardCharsets;importjava.util.HashMap;importjava.util.Map;/**
* @Description: Topic模式生产者
* @Author: hong
* @Date: 2024-01-16 20:09
* @Version: 1.0
**/publicclassTopicSend{privatestaticfinalStringEXCHANGE_NAME="topic_logs";publicstaticvoidmain(String[] args)throwsException{Channel channel =RabbitMQUtil.getChannel();
channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.TOPIC);Map<String,String> bindingKeyMap =newHashMap<>();
bindingKeyMap.put("quick.orange.rabbit","被队列 Q1Q2 接收到");
bindingKeyMap.put("lazy.orange.elephant","被队列 Q1Q2 接收到");
bindingKeyMap.put("quick.orange.fox","被队列 Q1 接收到");
bindingKeyMap.put("lazy.brown.fox","被队列 Q2 接收到");
bindingKeyMap.put("lazy.pink.rabbit","虽然满足两个绑定但只被队列 Q2 接收一次");
bindingKeyMap.put("quick.brown.fox","不匹配任何绑定不会被任何队列接收到会被丢弃");
bindingKeyMap.put("quick.orange.male.rabbit","是四个单词不匹配任何绑定会被丢弃");
bindingKeyMap.put("lazy.orange.male.rabbit","是四个单词但匹配 Q2");for(Map.Entry<String,String> bindingKeyEntry : bindingKeyMap.entrySet()){String bindingKey = bindingKeyEntry.getKey();String message = bindingKeyEntry.getValue();
channel.basicPublish(EXCHANGE_NAME, bindingKey,null, message.getBytes(StandardCharsets.UTF_8));System.out.println("消息发送完成------"+bindingKey+ message);}}}
3.消费者1
packagecom.hong.rabbitmq8;importcom.hong.utils.RabbitMQUtil;importcom.rabbitmq.client.BuiltinExchangeType;importcom.rabbitmq.client.CancelCallback;importcom.rabbitmq.client.Channel;importcom.rabbitmq.client.DeliverCallback;importjava.nio.charset.StandardCharsets;/**
* @Description: Topic模式接受者1-接收*.orange.*
* @Author: hong
* @Date: 2024-01-16 20:07
* @Version: 1.0
**/publicclassTopicReceiver1{publicstaticfinalStringEXCHANGE_NAME="topic_logs";publicstaticvoidmain(String[] args)throwsException{Channel channel =RabbitMQUtil.getChannel();
channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.TOPIC);String queueName ="Q1";
channel.queueDeclare(queueName,false,false,false,null);
channel.queueBind(queueName,EXCHANGE_NAME,"*.orange.*");DeliverCallback deliverCallback =(comsumerTag, message)->{System.out.println("接收队列:"+ queueName +",routingKey:"+ message.getEnvelope().getRoutingKey()+",消息:"+newString(message.getBody(),StandardCharsets.UTF_8));};CancelCallback cancelCallback =var->{};
channel.basicConsume(queueName,true,deliverCallback,cancelCallback);}}
4.消费者2
packagecom.hong.rabbitmq8;importcom.hong.utils.RabbitMQUtil;importcom.rabbitmq.client.BuiltinExchangeType;importcom.rabbitmq.client.CancelCallback;importcom.rabbitmq.client.Channel;importcom.rabbitmq.client.DeliverCallback;importjava.nio.charset.StandardCharsets;/**
* @Description: Topic模式接受者1-接收*.*.rabbit和lazy.#
* @Author: hong
* @Date: 2024-01-16 20:07
* @Version: 1.0
**/publicclassTopicReceiver2{publicstaticfinalStringEXCHANGE_NAME="topic_logs";publicstaticvoidmain(String[] args)throwsException{Channel channel =RabbitMQUtil.getChannel();
channel.exchangeDeclare(EXCHANGE_NAME,BuiltinExchangeType.TOPIC);String queueName ="Q2";
channel.queueDeclare(queueName,false,false,false,null);
channel.queueBind(queueName,EXCHANGE_NAME,"*.*.rabbit");
channel.queueBind(queueName,EXCHANGE_NAME,"lazy.#");DeliverCallback deliverCallback =(comsumerTag, message)->{System.out.println("接收队列:"+ queueName +",routingKey:"+ message.getEnvelope().getRoutingKey()+",消息:"+newString(message.getBody(),StandardCharsets.UTF_8));};CancelCallback cancelCallback =var->{};
channel.basicConsume(queueName,true,deliverCallback,cancelCallback);}}
例子说明quick.orange.rabbit被队列 Q1Q2 接收到lazy.orange.elephant被队列 Q1Q2 接收到quick.orange.fox被队列 Q1 接收到lazy.brown.fox被队列 Q2 接收到lazy.pink.rabbit虽然满足两个绑定但只被队列 Q2 接收一次quick.brown.fox不匹配任何绑定不会被任何队列接收到会被丢弃quick.orange.male.rabbit是四个单词不匹配任何绑定会被丢弃lazy.orange.male.rabbit是四个单词但匹配 Q2
版权归原作者 Java小生不才 所有, 如有侵权,请联系我们删除。