消息中间件rabbitmq

Posted dengyu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了消息中间件rabbitmq相关的知识,希望对你有一定的参考价值。

介绍

技术分享图片

注:没有注册中心,总共只分为三个角色,product,server,customer。

Queue

消息队列,等同于rocketmq中的topic

Exchange

生产者产生的消息并不是直接发送给消息队列Queue的,而是要经过Exchange(交换器),由Exchange再将消息路由到一个或多个Queue,当然这里还会对不符合路由规则的消息进行丢弃掉,这里指的是后续要谈到的Exchange Type。那么Exchange是怎样将消息准确的推送到对应的Queue的呢?那么这里的功劳最大的当属Binding,RabbitMQ是通过Binding将Exchange和Queue链接在一起,这样Exchange就知道如何将消息准确的推送到Queue中去。简单示意图如下所示:

技术分享图片

主要介绍下Topic的路由规则

topic这个规则就是模糊匹配,可以通过通配符满足一部分规则就可以传送。它的约定是:

  1. routing key为一个句点号“. ”分隔的字符串(我们将被句点号“. ”分隔开的每一段独立的字符串称为一个单词),如“stock.usd.nyse”、“nyse.vmw”、“quick.orange.rabbit”
  2. binding key与routing key一样也是句点号“. ”分隔的字符串
  3. binding key中可以存在两种特殊字符“*”与“#”,用于做模糊匹配,其中“*”用于匹配一个单词,“#”用于匹配多个单词(可以是零个)技术分享图片
Exchange规则
类型名称 类型描述
fanout 把所有发送到该Exchange的消息路由到所有与它绑定的Queue中
direct Routing Key==Binding Key
topic 我这里自己总结的简称模糊匹配
headers Exchange不依赖于routing key与binding key的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配。

以上是关于消息中间件rabbitmq的主要内容,如果未能解决你的问题,请参考以下文章

消息中间件-----RabbitMq消息可靠传递

RabbitMQ 消息中间件

揭开消息中间件RabbitMQ的神秘面纱

十次方项目第五天(消息中间件RabbitMQ)

消息中间件Rabbitmq的使用

RabbitMQ 消息中间件