当前位置: 首页 > news >正文

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)。

    图片

    http://www.dtcms.com/a/291642.html

    相关文章:

  • 【无标题】buuctf-re3
  • 解决pip指令超时问题
  • MCU中的总线桥是什么?
  • Windows PE文件内未用空间学习
  • Collection接口的详细介绍以及底层原理——包括数据结构红黑树、二叉树等,从0到彻底掌握Collection只需这篇文章
  • wed前端简单解析
  • wangEditor5添加键盘事件/实现定时保存功能
  • 【文献笔记】ARS: Automatic Routing Solver with Large Language Models
  • SpringMVC快速入门之启动配置流程
  • C语言基础:函数练习题
  • 【洛谷】用两个数组实现静态单链表、静态双向链表,排队顺序
  • C#初学知识点总结
  • 假发行业数字化突围,外贸ERP重构外协管理引擎,助力效率飞跃
  • 智联智造:国内新能源汽车品牌AGV小车无线控制系统创新实践
  • 面试题:sql题一
  • 前端项目启动后,只有localhost地址,没有ip地址
  • vs2017 c++ 使用sqlite3数据库
  • Java 邂逅 WebSocket:解锁实时通信的无限可能​
  • Flutter基础(前端教程①⑦-Column竖直-Row水平-Warp包裹-Stack堆叠)
  • 【计算机网络 篇】TCP基本认识和TCP三次握手相关问题
  • ArKTS: DAL,Model,BLL,Interface,Factory using SQLite
  • docker-desktop启动失败
  • 【电影剖析】千钧一发
  • 从 “能用“ 到 “好用“:中小制造企业数字化转型中的 IT 系统优化管理策略
  • 【openbmc6】entity-manager
  • C# 转换(is和as运算符)
  • 【人工智能99问】transformer的编码器和解码器是如何协同工作的?(15/99)
  • 【面经】实习经历
  • Thread 类
  • Java注解家族--`@ResponseBody`