RabbitMQ-交换机(Exchange)

作者介绍:简历上没有一个精通的运维工程师。请点击上方的蓝色《运维小路》关注我,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。

中间件,我给它的定义就是为了实现某系业务功能依赖的软件,包括如下部分:

Web服务器

代理服务器

ZooKeeper

Kafka

RabbitMQ(本章节)

前面的内容,我们介绍了虚拟主机(vhost),但是它只是一个逻辑概念,它必须配合对应的交换机(Exchange),队列(Queue),绑定(Binding)才能具体使用,今天我们首先来介绍的是交换机。

交换机(Exchange)

交换机是接收生产者发送消息的组件,它的主要功能是根据特定的规则将消息路由到一个或多个队列中。可以简单的理解消息首先会到交换机,然后才会分发出去,这个和传统的物理交换机实际比较类似。

交换机类型

RabbitMQ 提供了四种主要的交换机类型,每种类型实现了不同的路由算法:

直连交换机(Direct Exchange):根据消息的路由键(routing key)将消息路由到与之绑定的队列中,绑定键(binding key)和路由键精确匹配时消息才会被路由。这个也是日常使用最多的交换机类型。

扇形交换机(Fanout Exchange):将接收到的所有消息广播到与之绑定的所有队列中,忽略路由键。

主题交换机(Topic Exchange):通过消息的路由键和绑定键的模式匹配来决定消息的路由。绑定键可以使用*(匹配一个单词)和#(匹配零个或多个单词)通配符。

头交换机(Headers Exchange):根据消息的头部信息而非路由键来进行消息路由,绑定规则通过消息头中的键值对来定义。

交换机属性

名称:交换机的唯一标识符,在 vhost 内必须唯一。

持久性(Durable):设置为 true 时,交换机会在 RabbitMQ 服务器重启后仍然存在。

自动删除(Auto-delete):当所有与之绑定的队列都解除绑定时,交换机将被自动删除。

内部(Internal):如果设置为 true,则该交换机不能直接接收生产者的消息,只能用于交换机之间的绑定。可以简单理解它只接收其他交换机发过来的信息。

默认交换机介绍

每创建一个虚拟主机(vhost),都会默认创建下面的交换机。

1.所有交换机都基于虚拟主机(vhost),这里默认都是在根(/)下面。

2.系统预设了部分交换机,其中第一个是没有指定交换机的的信息会被这个默认交换机收取。

3.就是前面指定的交换机类型。

4."D"代表持久化(重启了还在)"I" 代表不对外

创建交换机

这里实际上就是前面哪些参数,前面提到过交换机具有自动删除就在这里配置,还有是否是内部交换机。Alternate exchange (备用交换机)我们后期讲解死信队列的时候来说。

创建交换机的时候,选择的虚拟主机必须要有对应的账号权限才可以,比如下图这样的权限,我如果给/test01 虚拟主机(vhost)创建交换机则会拒绝。

后面的操作,我们尽量使用页面来完成。

下图的ceph115就是交换机(Exchange),位于虚拟主机(vhost)/test 下,交换机类型是使用最多的直连交换机(Direct Exchange)。

相关推荐
嵌入式学习和实践14 分钟前
虚拟机 Ubuntu 磁盘扩容完全指南:从原理到实践,一步到位
linux·ubuntu·磁盘扩容
陳103037 分钟前
Linux:进程间切换与调度
linux·运维·服务器
lcreek1 小时前
Linux 虚拟文件系统的建立与使用全过程解析
linux·虚拟文件系统·vfs
寒秋花开曾相惜1 小时前
(学习笔记)第四章 处理器体系结构
linux·网络·数据结构·笔记·学习
霖霖总总1 小时前
[Redis小技巧32]Redis分布式锁的至暗时刻:从原理演进到时钟跳跃的终极博弈
数据库·redis·分布式
疏星浅月2 小时前
虚拟内存三大核心作用详解
linux·c语言·arm开发·嵌入式硬件
ZC跨境爬虫2 小时前
Scrapy分布式爬虫(单机模拟多节点):豆瓣Top250项目设置与数据流全解析
分布式·爬虫·python·scrapy
邂逅星河浪漫3 小时前
【银行内网开发-管理端】Vue管理端+Auth后台开发+Nginx配置+Linux部署(详细解析)
linux·javascript·css·vue.js·nginx·html·前后端联调
码农小钻风3 小时前
利用Samba实现局域网跨平台共享文件
linux·samba·共享
LN花开富贵4 小时前
【ROS】鱼香ROS2学习笔记二
linux·笔记·python·学习·嵌入式