第四章 RabbitMQ消息队列

消息队列

两种工作模式

Point-to-Point

  • 一方发送消息,另一方接收

Pub/Sub

  • 即发布/订阅模式,消费者可以订阅一个或多个主题并使用该主题中的所有消息

缺点

  • 系统可用性降低
  • 系统复杂性提高
  • 数据一致性无法保证

RabbitMQ

RabbitMQ相关术语

  • 生产者:产生消息的进程或服务
  • 消费者:接收消息的进程或服务
  • 队列:RabbitMQ 是消息队列中间件,而真正储存消息数据的就是队列,队列可以有很多。
  • 交换器:类似于网络设备交换机,它可以根据不同的关键字,将消息发送到不同的队列。
  • 虚拟主机:虚拟主机提供了资源的逻辑分组和分隔,每一个虚拟主机本质上是 mini 版的 RabbitMQ 服务器

RabbitMQ架构

tags角色

|----------------------------|-----------------------------------------------------------------------------|
| 角色 | 说明 |
| 超级管理员(administrator):guest | 可登陆管理控制台(启用management plugin的情况下),可查看所有的信息,并且可以对用户,策略(policy)进行操作。 |
| 监控者(monitoring) | 可登陆管理控制台(启用management plugin的情况下),同时可以查看rabbitmq节点的相关信息(进程数,内存使用情况,磁盘使用情况等) |
| 策略制定者(policymaker) | 可登陆管理控制台(启用management plugin的情况下), 同时可以对policy进行管理。但无法查看节点的相关信息。 |
| 普通管理者(management) | 仅可登陆管理控制台(启用management plugin的情况下),无法看到节点信息,也无法对策略进行管理。 |
| 其他 | 无法登陆管理控制台,通常就是普通的生产者和消费者。 |

相关推荐
芊言芊语23 分钟前
分布式缓存服务Redis版解析与配置方式
redis·分布式·缓存
月夜星辉雪4 小时前
【RabbitMQ 项目】服务端:路由交换模块
分布式·rabbitmq
super_journey4 小时前
RabbitMq中交换机(Exchange)、队列(Queue)和路由键(Routing Key)
分布式·中间件·rabbitmq
灰色孤星A6 小时前
分布式事务学习笔记(二)Seata架构、TC服务器部署、微服务集成Seata
分布式·微服务·架构·seata·分布式事务·tc服务器·微服务集成seata
王彬泽7 小时前
【RabbitMQ】重试机制、TTL
rabbitmq·ttl·重试机制
MinIO官方账号7 小时前
从 HDFS 迁移到 MinIO 企业对象存储
人工智能·分布式·postgresql·架构·开源
丁总学Java8 小时前
maxwell 输出消息到 kafka
分布式·kafka·maxwell
海里真的有鱼9 小时前
Spring Boot 项目中整合 RabbitMQ,使用死信队列(Dead Letter Exchange, DLX)实现延迟队列功能
开发语言·后端·rabbitmq
喜欢猪猪9 小时前
深度解析ElasticSearch:构建高效搜索与分析的基石原创
分布式
蘑菇蘑菇不会开花~10 小时前
分布式Redis(14)哈希槽
redis·分布式·哈希算法