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. 小结
4994 0
Element el-date-picker 日期选择器详解
|
Linux 开发工具 Windows
中国时间服务器,国内阿里云时间服务器
中国时间服务器,国内阿里云时间服务器很多用户使用的是国外VPS使用过程中常常遇到时间与国内不同步的情况好在阿里提供了7台NTP服务器,地址如下:阿里云提供了7个NTP时间服务器也就是Internet时间同步服务器地址 ntp1.
37649 0
|
28天前
|
消息中间件 存储 运维
云消息队列 Kafka 版全面升级:经济、弹性、稳定,成本比自建最多降低 82%
本文介绍了阿里云云消息队列 Kafka 版的全面升级,强调了其在经济性、稳定性和弹性方面的显著提升。同时,与 Apache Kafka 相比,云消息队列 Kafka 版通过节省 66% 的资源,实现了客户使用成本比自建最多降低 82%。
|
22天前
|
Ubuntu
Ubuntu禁止内核自动更新
通过上述步骤,您可以在Ubuntu系统中有效地禁用内核的自动更新。这些步骤包括锁定内核版本、禁用自动更新配置、移除不需要的内核包以及禁用相关的自动更新服务。这样可以确保系统在内核层面保持稳定,避免因内核自动更新导致的不必要问题。
140 1
|
1月前
|
人工智能 自然语言处理 IDE
|
2月前
|
Cloud Native 关系型数据库 Serverless
基于阿里云函数计算(FC)x 云原生 API 网关构建生产级别 LLM Chat 应用方案最佳实践
本文带大家了解一下如何使用阿里云Serverless计算产品函数计算构建生产级别的LLM Chat应用。该最佳实践会指导大家基于开源WebChat组件LobeChat和阿里云函数计算(FC)构建企业生产级别LLM Chat应用。实现同一个WebChat中既可以支持自定义的Agent,也支持基于Ollama部署的开源模型场景。
443 16
|
4月前
数据库系统工程师考点笔记
数据库系统工程师考点笔记
441 0
|
6月前
|
存储 Unix 程序员
非常详细!操作系统基础【文件系统实现】
非常详细!操作系统基础【文件系统实现】
|
人工智能 自然语言处理 搜索推荐
AIGC之自然语言处理技术
阿里云AIGC是阿里云人工智能集成平台,它为开发者提供了丰富的AI能力,涵盖了自然语言处理、图像处理、声音处理等多个领域。它可以创造一个高效的,按需使用的开发和运营环境,帮助企业开发AI应用和服务,提升UI和用户体验,深挖用户价值和增强竞争优势。
430 0
|
XML JSON 算法
JWT详细讲解(保姆级教程)
本篇博文详细讲解JWT概念,组成,运行过程,和SAM相比的优势,并附加SpringBoot整合JWT的案例。
JWT详细讲解(保姆级教程)