01 RabbitMQ:简单介绍

01 RabbitMQ:简单介绍

  • [1. 简单介绍](#1. 简单介绍)
    • [1.1. 什么是消息队列?](#1.1. 什么是消息队列?)
    • [1.2. 底层实现两大主流方式](#1.2. 底层实现两大主流方式)
    • [1.3. 两大主流方式对比](#1.3. 两大主流方式对比)
    • [1.4. 各个MQ产品的对比](#1.4. 各个MQ产品的对比)
  • [2. RabbitMQ简介](#2. RabbitMQ简介)
    • [1.2. 官网](#1.2. 官网)
    • [1.3. 体系结构](#1.3. 体系结构)
      • [1.3.1. Producer](#1.3.1. Producer)
      • [1.3.2. Consumer](#1.3.2. Consumer)
      • [1.3.3. Connection](#1.3.3. Connection)
      • [1.3.4. Channel](#1.3.4. Channel)
      • [1.3.5. Broker](#1.3.5. Broker)
      • [1.3.6. Virtual Host](#1.3.6. Virtual Host)
      • [1.3.7. Exchange](#1.3.7. Exchange)
      • [1.3.8. Queue](#1.3.8. Queue)
      • [1.3.9. Broker到Consumer](#1.3.9. Broker到Consumer)
      • [1.3.10. Exchange到Queue](#1.3.10. Exchange到Queue)

1. 简单介绍

1.1. 什么是消息队列?


消息队列: 实现 应用程序应用程序 之间 通信 的中间件产品。
应用程序 可以理解为,分布式环境下的 微服务

1.2. 底层实现两大主流方式

1.3. 两大主流方式对比

(了解即可)

1.4. 各个MQ产品的对比

RabbitMQ: 单机吞吐量每秒十万左右级别,很厉害。
RabbitMQ: 单机吞吐量每秒数万级,感觉一般。
RocketMQ: 单机吞吐量每秒十万+级,经历过双11,很厉害。
Kafka: 单机吞吐量每秒百万级,更厉害。有兴趣的小伙伴可以学习一下。

2. RabbitMQ简介

1.2. 官网

RabbitMQ: One broker to queue them all | RabbitMQ

RabbitMQ是一款 基于AMQP、由Erlang语言开发 的消息队列产品。

1.3. 体系结构

1.3.1. Producer

1.3.2. Consumer

1.3.3. Connection

当生产者想要发送消息到服务器的时候,必须建立个连接。

由于该连接是TCP连接,需要三次握手反复确认。如果每次发消息(访问RabbitMQ服务器)都新建个连接(Connection),开销太大,效率太低。

1.3.4. Channel

为了实现 Connection 的复用,在 Connection 内部创建多个 Channel

如果应用程序支持多线程,那么每个线程创建一个单独的 Channel 进行通讯。每个 Channel 都有自己的 idChannel 之间是完全隔离的。所以实际上每次发送消息,都是 Connection 内部的 Channel 完成的。

1.3.5. Broker

Broker实际就是RabbitMQ的主体服务器本身。

如果搭建RabbitMQ集群,集群里面会有多个 Broker 的实例。

1.3.6. Virtual Host

Broker 实例内,可以根据项目和功能划分多个虚拟分组。每个虚拟分组称为 Virtual Host

用户在自己的 Virtual Host 中使用RabbitMQ组件。在实际开发中,通过 Virtual Host 区分不同项目、不同功能。

1.3.7. Exchange

Virtual Host 内部会包含多个 Exchange 。中文翻译:交换机,是消息达到 Broker 的第一站。

也就是说,当我们发消息的时候,是把消息先发送到 交换机(Exchange) 上,再通过 交换机(Exchange) 这个中转站,将消息发送到 队列(Queue) 上。

1.3.8. Queue

Queue: 队列就是消息存放的的容器。

队列(Queue) 也会有多个~

📣📣📣注意:

消息只是在 交换机(Exchange) 内中转,并不会存储消息。

消息存储是在 队列(Queue) 中存储的。消息如果被消费端取走以后,消息会在 队列(Queue) 中删除。

1.3.9. Broker到Consumer

消费者(Consumer)Broker 建立连接与生产者(Producer)和 Broker 建立连接相同的道理。Channel

为了实现 Connection 的复用。

1.3.10. Exchange到Queue

如何确认消息在 交换机(Exchange) 内中转到哪个 队列(Queue) 呢?两者之间会有个绑定关系,通过路由键的方式,将 交换机(Exchange)队列(Queue) 绑定在一起。

交换机(Exchange) 可以绑定一个 队列(Queue) ,也可以绑定多个 队列(Queue)


本文隶属于 【个人专栏】:06 RabbitMQ 📋📋📋

到这里 01 RabbitMQ:简单介绍 就结束了!!!🎉🎉🎉

后续接 02 RabbitMQ:实际操作 📣📣📣

欢迎小伙伴们学习和指正!!!😊😊😊

祝大家学习和工作一切顺利!!!😎😎😎

相关推荐
ALex_zry1 小时前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
为什么不问问神奇的海螺呢丶3 小时前
n9e categraf rabbitmq监控配置
分布式·rabbitmq·ruby
TTBIGDATA7 小时前
【Atlas】Atlas Hook 消费 Kafka 报错:GroupAuthorizationException
hadoop·分布式·kafka·ambari·hdp·linq·ranger
m0_687399849 小时前
telnet localhost 15672 RabbitMQ “Connection refused“ 错误表示目标主机拒绝了连接请求。
分布式·rabbitmq
陌上丨10 小时前
生产环境分布式锁的常见问题和解决方案有哪些?
分布式
新新学长搞科研10 小时前
【智慧城市专题IEEE会议】第六届物联网与智慧城市国际学术会议(IoTSC 2026)
人工智能·分布式·科技·物联网·云计算·智慧城市·学术会议
Ronin30510 小时前
日志打印和实用 Helper 工具
数据库·sqlite·rabbitmq·文件操作·uuid生成
泡泡以安10 小时前
Scrapy分布式爬虫调度器架构设计说明
分布式·爬虫·scrapy·调度器
没有bug.的程序员12 小时前
RocketMQ 与 Kafka 深度对垒:分布式消息引擎内核、事务金融级实战与高可用演进指南
java·分布式·kafka·rocketmq·分布式消息·引擎内核·事务金融
上海锟联科技12 小时前
250MSPS DAS 在地铁监测中够用吗?——来自上海锟联科技的工程实践
分布式·科技·分布式光纤传感·das解调卡·光频域反射·das