RabbimMQ简单介绍

简介: RabbimMQ简单介绍

什么是RabbimMQ

MQ(MessageQueue)消息队列,是分布式系统中的通信手段,在消息的传输过程中保存消息的容器,多用于分布式系统之间进行通信 RabbimMQ是MQ众多产品中表现比较优秀的产品之一

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

远程访问直接通信

通过第三方工具间接通信


MQ总结

1 MQ,消息队列.存储消息的中间价

2 分布式系统通信方式有两种:直接远程访问和借助第三方完成间接通信(MQ就属于后者)

3 发送方(生产消息)的称为生产者,接受方(消费)消息称为消费者


  1. MQ的优势和劣势

优势

1 应用解耦(提升系统的容错性和可维护性)

传统分布式系统 如果分布式系统中某个系统出错,会影响整个系统,系统的耦合性越高,容错率就越低,可维护性就越低


image.png


 使用MQ的分布式系统使得应用间解耦,提升容错性和可维护性


image.png


2 异步提速(提升用户体验和系统吞吐量)

传统分布式系统,一个操作要耗时大量时间,响应太慢,用户的体检比较差


image.png


使用MQ的分布式系统,异步处理,MQ只需要告诉用户操作成功或者失败,不需要管其他系统的反馈,提升用户体验和系统吞吐量(单位时间内处理请求的数目)


image.png


3 削峰填谷(提高系统稳定性)

传统的分布式系统,不能保证用户的并发量,如果并发量太大,系统会宕机,用户体检极差

image.png


使用MQ的分布式系统,全部的并发量不会直接访问系统,而是直接由MQ接收,然后再由系

统慢慢从MQ拉取请求进行处理,保证了系统的稳定性


image.png


image.png


劣势

  1 系统可用性降低

系统引入的外部依赖越多,需要维护保证稳定的东西就越多,一旦MQ宕机,就会对业务造成影响

  2 系统复杂度提高

MQ的加入大大的增加了系统的复杂度,以前系统间是同步的远程调用,现在是通过MQ异步调用,需要考虑并解决消息有没有被重复消费,怎么处理消息丢失情况,怎么保证消息传递的顺序性

  3 一致性问题

A系统处理完业务,通过MQ给B,C,D三个系统发消息数据,如果B系统,C系统处理成功,D系统处理失败,如何保证消息数据处理的一致性

  1. 使用MQ需要满足什么样的条件

1 生产者不需要从消费者处反馈,引入消息队列之前的直接调用,其接口的返回值应该为空

2 允许短暂的不一致性

3 确实使用之后有效果,即解耦,提速,削峰这些方面的收益超过加入MQ,管理维护MQ这方面的成本,如果是一个简单的功能,引用MQ之后让系统变得更为复杂,这就没有使用MQ的必要了

  1. 常见的MQ产品

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

RabbitMQ和Spring是一家公司,和Spring可依赖度很高


image.png


  1. RabbitMQ简介

AMQP协议

AMQP,即Advanced Message Queing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制,2006年,AMQP协议发布,类比HTTP协议


2007年,Rabbit技术公司基于AMQP协议标准开发RabbitMQ1.0发布,RabbitMQ采用Erlang语言开发,Erlang语言由Ericson设计,专门为开发高并发和分布式系统的一种语言,在商业广泛使用


RabbitMQ的六种工作模式

RabbitMQ提供了六种工作模式:simple简单模式、work工作模式、publish/subscribe订阅模式、routing路由模式、topic 主题模式、RPC远程调用模式。

JMS

JMS即Java服务(JavaMessageService)应用程序接口,是一个Java平台中关于面向消息中间件的API,它是JavaEE规范的一种,类似JDBC

很多消息中间件都实现类JMS规范,类如:ActiveMQ,但是RabbitMQ官方没有提供JMS的实现包,但是开源社区有,有免费的也有收费的

RabbitMQ总结

1 RabbitMQ是基于AMQP协议使用Erlang语言开发的一款消息队列产品

2 RabbitMQ提供了六种工作模式

3 AMQP是一个协议,类比HTTP

4 JMS是API规范接口,类比JDBC

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
关系型数据库 MySQL 数据库
Element el-date-picker 日期选择器详解
本文目录 1. 前言 2. 基本用法 3. 日期格式化 4. 选择其他日期单位 5. 选择多个日期 6. 带快捷选项 7. 禁用部分日期 8. 小结
5137 0
Element el-date-picker 日期选择器详解
|
存储 编解码 算法
信道编码概述 |带你读《5G空口特性与关键技术》之六
纠错编码的目的,是通过尽可能小的冗余开销确保接收端能自动地纠正数据传输中所发生的差错。在同样的误码率下,所需要的开销越小,编码的效率也就越高。
11552 2
信道编码概述 |带你读《5G空口特性与关键技术》之六
|
Linux 开发工具 Windows
中国时间服务器,国内阿里云时间服务器
中国时间服务器,国内阿里云时间服务器很多用户使用的是国外VPS使用过程中常常遇到时间与国内不同步的情况好在阿里提供了7台NTP服务器,地址如下:阿里云提供了7个NTP时间服务器也就是Internet时间同步服务器地址 ntp1.
38193 0
|
2月前
|
消息中间件 存储 运维
云消息队列 Kafka 版全面升级:经济、弹性、稳定,成本比自建最多降低 82%
本文介绍了阿里云云消息队列 Kafka 版的全面升级,强调了其在经济性、稳定性和弹性方面的显著提升。同时,与 Apache Kafka 相比,云消息队列 Kafka 版通过节省 66% 的资源,实现了客户使用成本比自建最多降低 82%。
204 10
|
3月前
|
JSON 安全 API
抖音店铺商品信息的 API
抖音店铺商品信息的 API 主要用于获取商品的详细信息,包括基本信息、属性、库存、评价、推广信息等。开发者需注册账号、申请权限、阅读文档、发送请求并处理响应。此外,还提供商品搜索和管理接口,帮助商家优化商品展示和管理订单,提高运营效率。使用时需遵守平台规则,确保数据安全和合法性。
|
8月前
|
存储 Unix 程序员
非常详细!操作系统基础【文件系统实现】
非常详细!操作系统基础【文件系统实现】
|
Java 数据安全/隐私保护 容器
【JavaWeb】案例:用户登录、用户自动登录
本期主要介绍案例:用户登录、用户自动登录
350 0
【JavaWeb】案例:用户登录、用户自动登录
|
人工智能 自然语言处理 搜索推荐
AIGC之自然语言处理技术
阿里云AIGC是阿里云人工智能集成平台,它为开发者提供了丰富的AI能力,涵盖了自然语言处理、图像处理、声音处理等多个领域。它可以创造一个高效的,按需使用的开发和运营环境,帮助企业开发AI应用和服务,提升UI和用户体验,深挖用户价值和增强竞争优势。
475 0
|
存储 缓存 弹性计算
阿里云Optane+QLC存储实践案例分享
本文主要分享主题在阿里云本地盘存储中,基于Optane SSD和SPDK WSR的功能,降低QLC SSD的写放大。
|
SQL 关系型数据库 MySQL