当前位置:   article > 正文

RabbitMQ 路由模式即直接交换机_rabbitmq路由键和交换机

rabbitmq路由键和交换机

1.路由交换机

这种类型的工作方式是,消息只去到它绑定的routing key的队列中去

2.实战

(1)图示

 (2)代码实现

  1. package com.rabbitmq.six;
  2. import com.rabbitmq.client.Channel;
  3. import com.rabbitmq.utils.MqUtils;
  4. import java.io.IOException;
  5. import java.util.Scanner;
  6. import java.util.concurrent.TimeoutException;
  7. public class DirectLogs {
  8. private static final String EXCHANGE_NAME = "direct_logs";
  9. public static void main(String[] args) throws IOException, TimeoutException {
  10. Channel channel = MqUtils.getChannel();
  11. Scanner scanner = new Scanner(System.in);
  12. while(scanner.hasNext()) {
  13. String message = scanner.next();
  14. // 先测试info然后改成warning重启,然后改成error重启测试
  15. channel.basicPublish(EXCHANGE_NAME, "info", null ,message.getBytes("UTF-8"));
  16. System.out.println("生产者发出消息:" + message);
  17. }
  18. }
  19. }
  1. package com.rabbitmq.six;
  2. import com.rabbitmq.client.BuiltinExchangeType;
  3. import com.rabbitmq.client.Channel;
  4. import com.rabbitmq.client.DeliverCallback;
  5. import com.rabbitmq.utils.MqUtils;
  6. import java.io.IOException;
  7. import java.util.concurrent.TimeoutException;
  8. public class ReceiveLogsDirect01 {
  9. private static final String EXCHANGE_NAME = "direct_logs";
  10. public static void main(String[] args) throws IOException, TimeoutException {
  11. Channel channel = MqUtils.getChannel();
  12. // 声明交换机-直接交换机(Direct)
  13. channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);
  14. // 声明队列
  15. channel.queueDeclare("console", false, false,false, null);
  16. // 绑定交换机与队列
  17. channel.queueBind("console", EXCHANGE_NAME, "info");
  18. channel.queueBind("console", EXCHANGE_NAME, "warning");
  19. // 接收消息
  20. DeliverCallback deliverCallback = (consumerTag, message) -> {
  21. System.out.println("ReceiveLogsDirect01控制台打印接收到的消息:" + new String(message.getBody(), "UTF-8"));
  22. };
  23. channel.basicConsume("console",true, deliverCallback,consumerTag->{});
  24. }
  25. }
  1. package com.rabbitmq.six;
  2. import com.rabbitmq.client.BuiltinExchangeType;
  3. import com.rabbitmq.client.Channel;
  4. import com.rabbitmq.client.DeliverCallback;
  5. import com.rabbitmq.utils.MqUtils;
  6. import java.io.IOException;
  7. import java.util.concurrent.TimeoutException;
  8. public class ReceiveLogsDirect02 {
  9. private static final String EXCHANGE_NAME = "direct_logs";
  10. public static void main(String[] args) throws IOException, TimeoutException {
  11. Channel channel = MqUtils.getChannel();
  12. // 声明交换机-直接交换机(Direct)
  13. channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);
  14. // 声明队列
  15. channel.queueDeclare("disk", false, false,false, null);
  16. // 绑定交换机与队列
  17. channel.queueBind("disk", EXCHANGE_NAME, "error");
  18. // 接收消息
  19. DeliverCallback deliverCallback = (consumerTag, message) -> {
  20. System.out.println("ReceiveLogsDirect02控制台打印接收到的消息:" + new String(message.getBody(), "UTF-8"));
  21. };
  22. channel.basicConsume("disk",true, deliverCallback,consumerTag->{});
  23. }
  24. }

(3)执行效果

 

 

 

 

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/708335
推荐阅读
相关标签
  

闽ICP备14008679号