系列目录

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的反智商设计,这设计的不实用又真废脑啊。

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

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

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

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

  8. RabbitMQ 入门系列:10、扩展内容:延时队列:延时队列插件及其有限的适用场景(系列大结局)。

    系列目录 RabbitMQ 入门系列:1.MQ的应用场景的选择与RabbitMQ安装. RabbitMQ 入门系列:2.基础含义:链接.通道.队列.交换机. RabbitMQ 入门系列:3.基础含义: ...

  9. 快速入门系列--WebAPI--01基础

    ASP.NET MVC和WebAPI已经是.NET Web部分的主流,刚开始时两个公用同一个管道,之后为了更加的轻量化(WebAPI是对WCF Restful的轻量化),WebAPI使用了新的管道,因 ...

随机推荐

  1. 2021.05.29【NOIP提高B组】模拟 总结

    T1 题意:给你一个图,可以不花代价经过 \(K\) 条边,问从起点到终点的最短路 考试的想法:设 \(dis_{i,j}\) 表示从起点免费了 \(j\) 条边到 \(i\) 的最短路 然后直接跑 ...

  2. Docker容器固定ip

    Docker容器固定IP 必须停止docker服务才能创建网桥 查看docker服务状态 停止docker服务 启动docker服务 [root@docker Tools]# systemctl st ...

  3. 2022年Web前端开发流程和学习路线(详尽版)

    前言 前端侧重于人机交互和用户体验,后端侧重于业务逻辑和大规模数据处理.理论上,面向用户的产品里,所有问题(包括产品.设计.后端.甚至看不见的问题)的表现形式,都会暴露在前端,而只有部分问题(数据问题 ...

  4. ffmpeg使用总结

    2021-07-21 初稿 截图 ffmpeg -i <video> -ss <time> -vframes 1 <output_pic> 设置视频封面 ffmpe ...

  5. bat-注册表

    注册表 注册表就像于是配置文件 linux下一切皆文件,windows下一切皆注册表 注册表(各种配置文件:系统设置.用户设置.软件的配置) HKEY_CLASSES_ROOT     超级管理员.系 ...

  6. nextInt和nextLine以及next方法的区别

    1.nextInt() 只读取整型的数据,输入读取完之后,光标仍在当前行. 2.nextLine() 扫描到一行内容,当遇见换行符时,结束扫描.一旦输入读取完毕,该方法会将光标移到下一行开始的位置. ...

  7. (零)机器学习入门与经典算法之numpy的基本操作

    1.根据索引来获取元素* 创建一个索引列表ind,用来装载索引,当numpy数据是一维数据时:一个索引对应的是一个元素具体的例子如下: import numpy as np # 数据是一维数据时:索引 ...

  8. Deep Learning-深度学习(一)

    深度学习入门 1.人工智能.机器学习.深度学习 1.1 人工智能(AI) 一个比较宽泛的概念.即用来模拟人的智能的理论,并对这个模拟出来的智能进行延伸和开拓.通俗来讲就是要达到用机器模拟人类的聪慧来处 ...

  9. MIT 6.824 Lab2C Raft之持久化

    书接上文Raft Part B | MIT 6.824 Lab2B Log Replication. 实验准备 实验代码:git://g.csail.mit.edu/6.824-golabs-2021 ...

  10. Kafka入门实战教程(7):Kafka Streams

    1 关于流处理 流处理平台(Streaming Systems)是处理无限数据集(Unbounded Dataset)的数据处理引擎,而流处理是与批处理(Batch Processing)相对应的.所 ...