首页 > 其他分享 >RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。

RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。

时间:2022-08-26 00:33:52浏览次数:120  
标签:进阶 队列 RabbitMQ topic 交换机 user 编码方式 channel

系列目录

RabbitMQ 入门系列:1、MQ的应用场景的选择与RabbitMQ安装。

RabbitMQ 入门系列:2、基础含义:链接、通道、队列、交换机。

RabbitMQ 入门系列:3、基础含义:持久化、排它性、自动删除、强制性、路由键。

RabbitMQ 入门系列:4、基础编码:官方SDK使用:链接创建、单例改造、发送消息、接收消息。

RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。

RabbitMQ 入门系列:6、保障消息:不丢失:发送方、Rabbit存储端、接收方。

RabbitMQ 入门系列:7、保障消息:不重复消费:产生消息的唯一ID。

RabbitMQ 入门系列:8、扩展内容:接收信息时:可否根据RoutingKey过滤监听信息,答案是不能。

RabbitMQ 入门系列:9、扩展内容:死信队列:真不适合当延时队列。

RabbitMQ 入门系列:10、扩展内容:延时队列:延时队列插件及其有限的适用场景。

前言:

本篇介绍交换机的进阶介绍及编码方式。

1、 交换机的类型:

在第二篇文时,曾简单介绍过交换机,但没太深入,那是为了避免入门阻碍太多。

本篇再稍为加深一下交换机的介绍,但也是点到为止:

交换机默认有4个类型:

direct:1条信息仅允许发送到1个队列。(RoutingKey匹配队列名)

fanout:1条信息发送到所有绑定的队列。(忽略RoutingKey)

header:1条信息发送到匹配的队队。(用header头部数据匹配)

topic:1条信息发送到匹配RoutingKey规则的队列。(一般用#和*通配符)

通配符号#(无视.点号)和*(遇到.点号则中止)说明:

topic.#那么这个队列会接收topic开头的消息,如topic.hello.world
topic.*那么这个队列只接收topic开头后面一个的消息,如topic.hello

1、交换机:direct类型及其使用编码

实际上,之前的介绍中,在使用的代码中都避开了交换机。

其实不是没用到,只是用到的是默认交换机(AMQP default):

1、它是direct类型,因此RoutingKey匹配队列名。

2、它默认通向所有的队列,即绑定了所有的队列。

3、交换机名称传值时默认传空值。

下面进行1个简单的消息发送:

channel.BasicPublish(“”, “first", false, null, Encoding.UTF8.GetBytes("这是要发送的内容aaa"));

从Web控制中心查看数据,可以看到,路由使用了默认的,而RoutingKey 则是对应了队列了名称。

3、交换机:fanout类型的使用编码

对fanout类型的使用,所有的routekey都传空值即可。

复制代码
using (var channel = Rabbit.Instance.DefaultConnection.CreateModel())
{
    //定义队列
    channel.QueueDeclare("user.order");
    channel.QueueDeclare("user.birth");

    //定义交换机
    channel.ExchangeDeclare("user", "fanout");

    //交换机绑定2个队列
    channel.QueueBind("user.order", "user", "");
    channel.QueueBind("user.birth", "user", "");

    //发送到交换机,直接到达2个队列
    channel.BasicPublish("user", "", false, null, Encoding.UTF8.GetBytes("两个队列都收到信息"));

}
复制代码

管理界面可以看到信息:

4、交换机:topic类型编码

对于交换机类型来说:

direct类型:队列名就是routing key。

fanout类型:只关注交换机名称,routing key都是空。

topic类型:只有这个是重心放在routing key,而不关心队列起名规则。

下在看代码(用first、first2、first3)来演示(演示前会清空数据):

复制代码
using (var channel = Rabbit.Instance.DefaultConnection.CreateModel())
{
   //定义交换机 channel.ExchangeDeclare("user_topic", "topic"); //交换机绑定3个队列 channel.QueueBind("first", "user_topic", "#.order"); channel.QueueBind("first2", "user_topic", "#.birth"); channel.QueueBind("first3", "user_topic", "#.birth");
//发送到交换机,直接到达2个队列 channel.BasicPublish("user_topic", "user.order", false, null, Encoding.UTF8.GetBytes("1队列都收到信息")); channel.BasicPublish("user_topic", "user.birth", false, null, Encoding.UTF8.GetBytes("2队列都收到信息")); }
复制代码

数据结果:

 

这里必须吐槽一下,这个规则的设计反智商啊:

这种设计,用topic模块,一个信息只能发送到一个队列:

泥媒,这真是妥委的direct加强版,还真是只能到一个队列,加了个匹配规则,变成一个很弱鸡的功能。

要同时满足发送到多个队列,就必须绑定多个绑定规则......

个人觉得设计应该反过来才对:

绑定交换机时,定义完整的路径,发布消息时,带上通配符,去匹配规则,达到可以发送一个或多个队列去才合理。

5、交换机:header类型及其使用编码

这个类型不常用,暂未想到应用场景,暂不介绍。 

总结:

本篇介绍如交换机介绍及以使用其发送消息到多个队列,特别是topic的路由key的反智商设计,这设计的不实用又真废脑啊。

版权声明:本文原创发表于 博客园,作者为 路过秋天 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。
个人微信公众号
创业QQ群:617713515
Donation(扫码支持作者):支付宝:
Donation(扫码支持作者):微信:
    转 https://www.cnblogs.com/cyq1162/p/16603461.html

标签:进阶,队列,RabbitMQ,topic,交换机,user,编码方式,channel
From: https://www.cnblogs.com/wl-blog/p/16626261.html

相关文章

  • RabbitMQ的安装部署
    简介:RabbitMQ是一个开源的基于erlang语言编写,支持多种语言,用于在分布式系统中存储消息,转发消息,具有高可用、高可扩、易用性。 基于RPM包的安装方法如下: 1、首先下载......
  • Elasticsearch进阶
    1.核心概念索引Index一个索引就是一个拥有几分相似特征的文档的集合。比如说,你可以有一个客户数据的索引,另一个产品目录的索引,还有一个订单数据的索引。一个索引由一个......
  • SpringBoot使用RabbitMq实现队列和延时队列
    闲来无事看了看RabbitMq的队列,总结了一些队列的实现方法,当然,免不了各种看别人的博客哈哈哈其中延时队列有两种方式,一种是使用TTl+死信队列实现,一种是直接用RabbitMq的官方......
  • RabbitMQ 入门系列:5、基础编码:交换机的进阶介绍及编码方式。
    系列目录RabbitMQ入门系列:1、MQ的应用场景的选择与RabbitMQ安装。RabbitMQ入门系列:2、基础含义:链接、通道、队列、交换机。RabbitMQ入门系列:3、基础含义:持久化、......
  • .Net Core&RabbitMQ消息转发可靠机制
    前言生产者发送消息到了队列,队列推送数据给了消费者,这里存在一些问题需要思考下生产者如何确保消息一定投递到了队列中RabbitMQ丢失了消息(下文暂不涉及这块)队列如......
  • 开坑之Acwing算法进阶课题单
    当初五折的时候冲动消费买下的,现在看题单内容挺丰富的,适合打基础,也适合存板子,于是回来刷.(不一定看视频)需要学习的知识点包括1图论1.1网络流1.1.1最大流1.1.1.1算......
  • docker之rabbitmq delayed message exchange
    创建dockerfileFROMrabbitmq:3.9.11-management-alpineCOPYrabbitmq_delayed_message_exchange-3.9.0.ez/pluginsRUNrabbitmq-pluginsenablerabbitmq_delayed_me......
  • RabbitMQ消息重复消费场景及解决方案
    消息重复消费MQ的一条消息被消费者消费了多次重复消费场景重现测试如何解决消息重复消费的问题编码解决消息重复消费测试消息重复消费什么是消息重复消费?首......
  • 彩虹女神跃长空,Go语言进阶之Go语言高性能Web框架Iris项目实战-模板与数据库EP02
    书接上回,上次我们搭建好了项目入口文件,同时配置了路由体系,接着就可以配置项目的模板了,这里我们采用Iris内置的模板引擎,事实上,采用模板引擎并不意味着前后端耦合,模板中的数......
  • Spring 高级 工厂后处理器模拟实现组件扫描-模拟ComponentScan 进阶
    一、自定义Bean后处理器Processorpackagecom.mangoubiubiu.show.a05.component;importcom.mangoubiubiu.show.a05.Config;importorg.springframework.beans.Bea......