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

零基础学习RabbitMQ(1)--概述

Rabbit是一个公司名,兔子的意思, MQ 即message Queue(消息队列)。RabbitMQ就是Rabbit公司开发的一个实现了AMQP的消息队列服务,是当前主流的消息中间件之一。

AMQP, 即Advanced Message Queuing Protocol(高级消息队列协议),是一个通用的应用层协议,提供统一消息服务的协议,为面向消息的中间件设计。基于此协议的客户端与消息中间件可以传递消息,并不受客户端或中间件,开发语言等条件的限制。

1. 什么是MQ

MQ (消息队列)从字面上看,本质上是个队列,先进先出,只不过存储的是消息。MQ多用于分布式系统之间进行通信。

系统之间的通信方式有两种:

  1. 同步通信:直接调用对方的服务,数据从一端发出后立即就可以到达另一端。
  2. 异步通信:数据从一端发出后,先进入一个容器进行临时存储,当到达某种条件后,再由这个容器发送给另一端。这里的容器就可以使用MQ

 2. MQ的作用

MQ主要工作是接收并转发消息,在不同的应用场景下可以展现不同的作用 

  1. 异步解耦:在业务流程中,一些操作可能会非常耗时,但并不需要即时返回结果,可以借助MQ把这些操作异步化,例如用户修改信息后需要系统审核,不必让用户在修改界面等待审核成功而是可以直接去做其它操作。
  2. 流量削峰:在访问量剧增时,例如秒杀或促销活动,服务器的处理速度跟不上就会崩溃,这时就可以使用MQ来控制量,将请求存储到MQ中,服务器根据自己的处理速度在MQ中获取请求进行处理。
  3. 消息分发:当多个系统需要对同一数据做出响应时,也可也使用MQ进行消息分发,比如支付成功后,支付系统可以向MQ发送消息,其它系统订阅该消息,无需轮询数据库。
  4. 延迟通知:在需要在待定时间后发送通知的场景中,可以使用MQ的延迟消息功能,比如在电子商务平台中,如果用户下单后一定时间内未支付,可以使用延迟队列在超时后自动取消订单。

3. 常见的MQ 

目前业界有很多的MQ产品,例如RabbitMQ, RocketMQ, ActiveMQ, Kafka,ZeroMQ等,这些消息队列各有侧重,在实际选型时需要结合自身需求以及MQ产品特征,综合考虑

  • Kafka:Kafka一开始的目的就是用于日志收集和传输,追求高吞吐量,性能卓越,单机吞吐达到十万级,在日志领域比较成熟,功能较为简单,主要支持简单的MQ功能,如果有日志采集需求,可以首选Kafka
  • RocketMQ:RocketMQ采用Java语言开发,由阿里巴巴开源,后来捐赠给了Apache.设计时借鉴了Kafka,并作出了一些自己的改进,在可用性,可靠性,以及稳定性等方面都有出色的表现,适合对于可靠性比较高,且并非比较大的场景,比如互联网金融,但支持的客户端语言不多。
  • RabbitMQ:采用Erlang语言开发,MQ功能比较完备,几乎支持所有主流语言,开源提供的界面也非常优化,性能较好,吞吐量达到万级,社区活跃度也比较高,适合中小型公司,数据量没有那么大,且并发没有那么高的场景 

 

http://www.lqws.cn/news/496855.html

相关文章:

  • iperf3使用方法
  • 无人驾驶汽车运动控制分为纵向控制和横向控制
  • DMDRS部署实施手册(ORACLE=》DM)
  • Spring Boot多数据源配置实战指南
  • Reactor模式与Proactor模式理解
  • 【c++八股文】Day3:inline与define与constexpr
  • Android手机屏幕分为几种
  • Docker高级管理--Dockerfile镜像制作
  • 【科技公司的管理】
  • 【目标检测】图像处理基础:像素、分辨率与图像格式解析
  • Spring AI框架的实战应用指南
  • vscode 插件
  • 以玄幻小说方式打开深度学习词嵌入算法!! 使用Skip-gram来完成 Word2Vec 词嵌入(Embedding)
  • 显示任何结构的数组对象数据【向上自动滚动】
  • 七层网络模型与电脑通信比喻
  • Typora无限续
  • [创业之路-438]:行业 - 互联网+X技术发展趋势、关键技术简介、行业发展趋势
  • 【第二章:机器学习与神经网络概述】03.类算法理论与实践-(2)朴素贝叶斯分类器
  • 【7】图像变换(上)
  • FPGA基础 -- Verilog 驱动强度(drive strength)与电荷强度(charge strength)
  • 黄晓明考博落榜,本人回应
  • react gsap动画库使用详解之scroll滑动动画
  • 2025年CSS最新高频面试题及核心解析
  • 16.数据聚合
  • LINUX 623 FTP回顾
  • 设计模式精讲 Day 12:代理模式(Proxy Pattern)
  • 手撕 Decoder
  • 将RESP.app的备份数据转码成AnotherRedisDesktopManager的格式
  • react gsap动画库使用详解之text文本动画
  • 山洪灾害智能监测站系统解决方案