RabbitMQ介绍

MQ的定义

RabbitMQ 即一个消息队列,主要是用来实现应用程序的异步和解耦,同时也能起到消息缓冲,消息分发的作用。

消息中间件最主要的作用是解耦,中间件最标准的用法是生产者生产消息传送到队列,消费者从队列中拿取消息并处理,生产者不用关心是谁来消费,消费者不用关心谁在生产消息,从而达到解耦的目的。

在分布式的系统中,消息队列也会被用在很多其它的方面,比如:分布式事务的支持,RPC的调用等等。

Rabbitmq系统最核心的组件是Exchange和Queue

消息队列,提供了FIFO的处理机制,具有缓存消息的能力。rabbitmq中,队列消息可以设置为持久化,临时或者自动删除。

MQ功能

  1. 流量削峰:高并发访问服务器时,为环节服务器压力,使用消息队列做的一个缓冲。把访问的用户放入MQ进行排队

2.应用解耦:一个系统直接调用其他系统,若其他系统发生故障,则整个流程业务就无法完成,若在两个系统之间加上消息队列,主系统先执行完成后才会发消息给队列,有队列去转达到其他系统,而主系统不收其影响。若期间子系统发生异常,队列分配消息给各个系统,同时队列会监督各子系统完成

3.异步处理:A调用B,B去处理,B要花费较长时间进行处理,A要等待B的处理结果。使用MQ之后,A无需等待B,A可以做自己的事情,等到B完成后发消息给队列MQ,再由MQ发消息给A

三、MQ的分类

1.ActiveMQ:高吞吐量,一般不丢失消息

2.Kafka: 适用于大数据,高吞吐量,日志采集功能。 但单机超过64个队列/分区,队列越多,CPU占用越高

4.RocketMQ: 消息领丢失

5.RabbitMQ: 时效性好

四、RabbitMQ

消息中间件,负责接收、存储和转发消息

五、四大核心

  1. 生产者

  2. 交换机

  3. 队列

  4. 消费者

六、六大核心(六大模式)

  1. 简单模式

  2. 工作模式

  3. 发布订阅模式

  4. 路由模式

  5. 主题模式

  6. 发布确认模式

七、工作原理

  1. Broker : 接收和发布消息的应用,即消息实体

  2. Wxchange:交换机(一个消息实体可以对应多交换机)

  3. Queue: 队列 (一个交换机可以对应多个队列)

  4. Channel :信道,即发消息的通道。 每一个生产者会与MQ之间都会建立一个连接Connection ,每一个链接里会有多个信道

  5. Connection : 链接,每次调用MQ都会建立一个链接,链接里有包含多个信道,每次发消息只占用一个信道,而不占用整个连接

  6. 绑定:每一个交换机与队列的链接就叫做绑定

相关推荐
陌小呆^O^7 小时前
Cmakelist.txt之Liunx-rabbitmq
分布式·rabbitmq
BestandW1shEs10 小时前
彻底理解消息队列的作用及如何选择
java·kafka·rabbitmq·rocketmq
bug_null2 天前
RabbitMQ消息可靠性保证机制4--消费端限流
rabbitmq
青石路2 天前
不依赖 Spring,你会如何自实现 RabbitMQ 消息的消费(一)
rabbitmq
呼啦啦啦啦啦啦啦啦2 天前
【Rabbitmq篇】RabbitMQ⾼级特性----持久性,发送⽅确认,重试机制
分布式·rabbitmq
斯普信专业组2 天前
RabbitMQ实战启程:从配置到故障排查的实战处理(下)
网络·分布式·rabbitmq
呼啦啦啦啦啦啦啦啦3 天前
【Rabbitmq篇】RabbitMQ⾼级特性----消息确认
分布式·rabbitmq
泰山小张只吃荷园3 天前
快速入门消息队列MQ、RabbitMQ
java·spring boot·分布式·spring·spring cloud·rabbitmq·java-rabbitmq
呼啦啦啦啦啦啦啦啦3 天前
基于SpringBoot+RabbitMQ完成应⽤通信
spring boot·rabbitmq·java-rabbitmq
小马爱打代码3 天前
SpringBoot 整合 RabbitMQ
spring boot·rabbitmq·java-rabbitmq