Hello World模式,告诉我们如何一对一发送和接收消息;

Work模式,告诉我们如何多管齐下高效的消费消息;
Publish/Subscribe模式,告诉我们如何广播消息
那么有没有灵活强一点的既可以高效消费,又可以同时送达多个消费者的模式?
有,这就是Routing模式,我又称之为Direct直连模式。

Routing模式

  • 一个生产者P,一个交换机X,多个消息队列Q以及多个消费者C

  • 在Exchange和Queue中,我们看到了不同的规则,也就是Routing Key

显然从图中的说明,我们就知道这是一个log日志根据级别派发消息的例子。熟悉Log日志系统的应该都知道,一般的log系统分为error、info、warn和debug等。从图中我们可以看出,将日志级别为error的定向的派发到第一个消息队列,将error、warn和info级别的日志派发到第一个消息队列。

该模型首先实现了定向派发,而不再是订阅模式那种广播式的派发。同一条消息既可以派发给一个Queue,也可以同时派发给两个或者多个Queue,这就是该模式的灵活之处。下面来看看实例

发送端

/*** Created by jackie on 17/8/7.*/
public class EmitLogDirect {private static final String EXCHANGE_NAME = "direct_logs";public static void main(String[] argv) throws Exception {ConnectionFactory factory = new ConnectionFactory();factory.setHost("192.168.3.161");Connection connection = factory.newConnection();Channel channel = connection.createChannel();channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);String severity = getSeverity(argv);String message = getMessage(argv);channel.basicPublish(EXCHANGE_NAME, severity, null, message.getBytes("UTF-8"));System.out.println(" [x] Sent '" + severity + "':'" + message + "'");channel.close();connection.close();}private static String getSeverity(String[] strings){if (strings.length < 1)return "info";return strings[0];}private static String getMessage(String[] strings){if (strings.length < 2)return "Hello World!";return joinStrings(strings, " ", 1);}private static String joinStrings(String[] strings, String delimiter, int startIndex) {int length = strings.length;if (length == 0 ) return "";if (length < startIndex ) return "";StringBuilder words = new StringBuilder(strings[startIndex]);for (int i = startIndex + 1; i < length; i++) {words.append(delimiter).append(strings[i]);}return words.toString();}
}
  • String severity = getSeverity(argv);通过程序参数赋值给Routing Key,作为发送消息的规则

  • String message = getMessage(argv);通过程序参数赋值作为消息实体发送到Queue

在run configurations中配置argv

*第一个参数是要绑定key的名称,第二个参数是要发送的消息内容

  • 运行后,可以在RabbitMQ管理应用中看到exchange,但是此时没有绑定queue,所以即使发送消息也没有queue会存储或者消费。

接收端

/*** Created by jackie on 17/8/7.*/
public class ReceiveLogsDirect {private static final String EXCHANGE_NAME = "direct_logs";public static void main(String[] argv) throws Exception {ConnectionFactory factory = new ConnectionFactory();factory.setHost("192.168.3.161");Connection connection = factory.newConnection();Channel channel = connection.createChannel();channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);String queueName = channel.queueDeclare().getQueue();if (argv.length < 1){System.err.println("Usage: ReceiveLogsDirect [info] [warning] [error]");System.exit(1);}for(String severity : argv){channel.queueBind(queueName, EXCHANGE_NAME, severity);}System.out.println(" [*] Waiting for messages. To exit press CTRL+C");Consumer consumer = new DefaultConsumer(channel) {@Overridepublic void handleDelivery(String consumerTag, Envelope envelope,AMQP.BasicProperties properties, byte[] body) throws IOException {String message = new String(body, "UTF-8");System.out.println(" [x] Received '" + envelope.getRoutingKey() + "':'" + message + "'");}};channel.basicConsume(queueName, true, consumer);}
}
  • channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);表示使用的exchange类型为Direct类型

  • 绑定的queue的名称也是通过program arguments指定的

这里两个参数info和error表示绑定了两个routing key,即如果发送routing key为info的消息该队列能接收到,如果发送routing key为error,该队列也能收到

运行情况

启动接收端代码,我们可以看到生成了Queue名称为amq.gen-ugjKo6t4y0PXPwoh3CeubA的队列,同时有routingKey=info和routingKey=error的绑定到了Exchange上。

这时候起送发送端给routingkey为info发送消息“hello world”,我们可以看到在接收端确实能够收到消息“hello world”,同理,这时候发送routingkey为error的消息,该队列同样能够接收到,因为队列同时绑定了两个routing key

这个就是Routing直连模式。

如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!如果您想持续关注我的文章,请扫描二维码,关注JackieZheng的微信公众号,我会将我的文章推送给您,并和您一起分享我日常阅读过的优质文章。

转载于:https://www.cnblogs.com/bigdataZJ/p/rabbitmq6.html

RabbitMQ入门-Routing直连模式相关推荐

  1. 消息队列RabbitMQ入门与5种模式详解

    1.RabbitMQ概述 简介: MQ全称为Message Queue,消息队列是应用程序和应用程序之间的通信方法: RabbitMQ是开源的,实现了AMQP协议的,采用Erlang(面向并发编程语言 ...

  2. linux发布微软消息队列,消息队列RabbitMQ入门与5种模式详解

    1.RabbitMQ概述 简介: MQ全称为Message Queue,消息队列是应用程序和应用程序之间的通信方法: RabbitMQ是开源的,实现了AMQP协议的,采用Erlang(面向并发编程语言 ...

  3. RabbitMQ学习(一) 直连模式

    RabbitMQ简介 RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件).RabbitMQ服务器是用Erlang语言编写的,而群集和故障转移是构建在开放电信 ...

  4. RabbitMQ入门-Topic模式

    上篇<RabbitMQ入门-Routing直连模式>我们介绍了可以定向发送消息,并可以根据自定义规则派发消息.看起来,这个Routing模式已经算灵活的了,但是,这还不够,我们还有更加多样 ...

  5. RabbitMQ入门到进阶

    1.MQ简介 MQ 全称为 Message Queue,是在消息的传输过程中保存消息的容器.多用于分布式系统 之间进行通信. 2.为什么要用 MQ 1.流量消峰 没使用MQ 使用了MQ 2.应用解耦 ...

  6. RabbitMQ入门到进阶(Spring整合RabbitMQSpringBoot整合RabbitMQ)

    1.MQ简介 MQ 全称为 Message Queue,是在消息的传输过程中保存消息的容器.多用于分布式系统 之间进行通信. ​ 编辑切换为居中 添加图片注释,不超过 140 字(可选) 2.为什么要 ...

  7. rabbitmq入门(四)Topics主题模式

    文章目录 Topics主题模式 代码实现 测试 总结 下一章 Topics主题模式 交换机类型为 topics - 将路由和某个模式匹配,# 匹配一个或者多个,* 匹配一个.例如交换机绑定的routi ...

  8. RabbitMQ入门(简介、搭建环境、五种工作模式)介绍

    1. RabbitMQ介绍 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然在同步消 ...

  9. RabbitMQ入门:路由(Routing)

    在上一篇博客<RabbitMQ入门:发布/订阅(Publish/Subscribe)>中,我们认识了fanout类型的exchange,它是一种通过广播方式发送消息的路由器,所有和exch ...

最新文章

  1. 最常用的CURL命令大全
  2. 近世代数--素理想--I是R的素理想↔R/I是整环
  3. [邻接表] 学习邻接表的表示方法+BFS
  4. 使用delphi 开发多层应用(二十二)使用kbmMW 的认证管理器
  5. java打印九九乘法表——CSDN博客
  6. 【AI视野·今日NLP 自然语言处理论文速览 第七期】Tue, 15 Jun 2021
  7. Mac安装sqlmap【亲测有用】
  8. Docker安装gbase8s数据库教程
  9. 如何利用 Google 开源的 TFCO 构建机器学习模型?
  10. vue+sentry 前端异常日志监控
  11. FE.ES-理解Event Loop
  12. 完整版商城PHP源码小程序,前后端+后台+小程序;访问地址在文末
  13. Symbian 调用Wap浏览器
  14. 宝塔面板 - 通过宝塔面板安装的mysql 默认密码是什么
  15. 网络与信息安全学习(七)
  16. XML的解析方法(如何解析XML)
  17. ceres学习笔记(四)
  18. JS 实现百度搜索功能
  19. 网页图片快速显示的六种办法
  20. 光谱响应函数概念与等效遥感反射率的计算

热门文章

  1. DEDE利用Ajax实现调用当前登录会员的信息简要说明
  2. hdu 1495 非常可乐(BFS)
  3. PPT资料下载 - 问题驱动的软件测试设计:强化测试用例设计
  4. CCF-CSP 201703-1 试题名称: 分蛋糕
  5. 用户进程与内核进程通信netlink实例
  6. PHP编译遇到的问题
  7. 3星|《数据思维:从数据分析到商业价值》:有趣的数据分析案例
  8. 对象的比较与排序(五):C#运算符重载
  9. vsftp本地用户,虚拟用户,匿名用户同时工作
  10. ViewPage+Fragment的使用例子