当前位置:网站首页>什么是消息队列?
什么是消息队列?
2022-07-06 23:41:00 【勤天】
目录
一、什么是消息队列
消息队列,也成为“消息中间件”
消息(Message)是指在应用间传送的数据。消息可以非常简单,比如只包含文本字符串,也可以更复杂,可能包含嵌入对象。
消息队列(Message Queue)是一种应用间的通信方式,消息发送后可以立即返回,由消息系统来确保消息的可靠传递。消息发布者只管把消息发布到 MQ 中而不用管谁来取,消息使用者只管从 MQ 中取消息而不管是谁发布的。这样发布者和使用者都不用知道对方的存在。
消息队列是一种应用间的异步协作机制,同时消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题。实现高性能,高可用,可伸缩和最终一致性架构。是大型分布式系统不可缺少的中间件。
二、消息队列应用场景
分别介绍在:异步处理,应用解耦,流量削锋和消息通讯四个场景。
1、异步处理
场景说明:用户注册后,需要发注册邮件和注册短信。传统的做法有两种1.串行的方式;2.并行方式。
(1)串行方式:将注册信息写入数据库成功后,发送注册邮件,再发送注册短信。以上三个任务全部完成后,返回给客户端。
(2)并行方式:将注册信息写入数据库成功后,发送注册邮件的同时,发送注册短信。以上三个任务完成后,返回给客户端。
1)串行与并行的区别?
假设三个业务节点每个使用50毫秒钟,不考虑网络等其他开销,则串行方式的时间是150毫秒,并行的时间可能是100毫秒。
因为CPU在单位时间内处理的请求数是一定的,假设CPU1秒内吞吐量是100次。则串行方式1秒内CPU可处理的请求量是7次(1000/150)。并行方式处理的请求量是10次(1000/100)。
小结:并行的方式可以提高处理的时间。
2)如以上案例描述,传统的方式系统的性能(并发量,吞吐量,响应时间)会有瓶颈。如何解决这个问题呢?
引入消息队列,将不是必须的业务逻辑,异步处理。改造后的架构如下:
按照以上约定,用户的响应时间相当于是注册信息写入数据库的时间,也就是50毫秒。注册邮件,发送短信写入消息队列后,直接返回,因此写入消息队列的速度很快,基本可以忽略,因此用户的响应时间可能是50毫秒。因此架构改变后,系统的吞吐量提高到每秒20 QPS。比串行提高了3倍,比并行提高了两倍。
小结:引入消息队列 大大提高传统方式的系统性能
2、应用解耦
场景说明:用户下单后,订单系统需要通知库存系统。传统的做法是,订单系统调用库存系统的接口。如下图:
传统模式的缺点:
1) 假如库存系统无法访问,则订单减库存将失败,从而导致订单失败;
2) 订单系统与库存系统耦合;
如何解决以上问题呢?引入应用消息队列后的方案,如下图:
- 订单系统:用户下单后,订单系统完成持久化处理,将消息写入消息队列,返回用户订单下单成功。
- 库存系统:订阅下单的消息,采用拉/推的方式,获取下单信息,库存系统根据下单信息,进行库存操作。
- 假如:在下单时库存系统不能正常使用。也不影响正常下单,因为下单后,订单系统写入消息队列就不再关心其他的后续操作了。实现订单系统与库存系统的应用解耦。
3、流量削锋
流量削锋也是消息队列中的常用场景,一般在秒杀或团抢活动中使用广泛。
应用场景:
秒杀活动,一般会因为流量过大,导致流量暴增,应用挂掉。为解决这个问题,一般需要在应用前端加入消息队列。
1)可以控制活动的人数;
2)可以缓解短时间内高流量压垮应用;
处理方式:
1)用户的请求,服务器接收后,首先写入消息队列。假如消息队列长度超过最大数量,则直接抛弃用户请求或跳转到错误页面;
2)秒杀业务根据消息队列中的请求信息,再做后续处理。
4、日志处理
日志处理是指将消息队列用在日志处理中,比如Kafka的应用,解决大量日志传输的问题。架构简化如下:
- 日志采集客户端,负责日志数据采集,定时写受写入Kafka队列;
- Kafka消息队列,负责日志数据的接收,存储和转发;
- 日志处理应用:订阅并消费kafka队列中的日志数据;
以下是新浪kafka日志处理应用案例:
(1) Kafka:接收用户日志的消息队列。
(2) Logstash:做日志解析,统一成JSON输出给Elasticsearch。
(3) Elasticsearch:实时日志分析服务的核心技术,一个schemaless,实时的数据存储服务,通过index组织数据,兼具强大的搜索和统计功能。
(4) Kibana:基于Elasticsearch的数据可视化组件,超强的数据可视化能力是众多公司选择ELK stack的重要原因。
5、消息通讯
消息通讯是指,消息队列一般都内置了高效的通信机制,因此也可以用在纯的消息通讯。比如实现点对点消息队列,或者聊天室等。
点对点通讯:
客户端A和客户端B使用同一队列,进行消息通讯。
聊天室通讯:
客户端A,客户端B,客户端N订阅同一主题,进行消息发布和接收,实现类似聊天室效果。
三、消息中间件案例
1、电商系统示例
消息队列采用高可用,可持久化的消息中间件。比如Active MQ,Rabbit MQ,Rocket Mq ,kafka
(1)应用将主干逻辑处理完成后,写入消息队列。消息发送是否成功可以开启消息的确认模式。(消息队列返回消息接收成功状态后,应用再返回,这样保障消息的完整性)
(2)扩展流程(发短信,配送处理)订阅队列消息。采用推或拉的方式获取消息并处理。
(3)消息将应用解耦的同时,带来了数据一致性问题,可以采用最终一致性方式解决。比如主数据写入数据库,扩展应用根据消息队列,并结合数据库方式实现基于消息队列的后续处理。
2、日志收集系统示例
消息队列采用高可用,可持久化的消息中间件。比如Active MQ,Rabbit MQ,Rocket Mq ,kafka
(1)应用将主干逻辑处理完成后,写入消息队列。消息发送是否成功可以开启消息的确认模式。(消息队列返回消息接收成功状态后,应用再返回,这样保障消息的完整性)
(2)扩展流程(发短信,配送处理)订阅队列消息。采用推或拉的方式获取消息并处理。
(3)消息将应用解耦的同时,带来了数据一致性问题,可以采用最终一致性方式解决。比如主数据写入数据库,扩展应用根据消息队列,并结合数据库方式实现基于消息队列的后续处理。
四、MQ的优点和缺点
优点:解耦、削峰、数据分发
缺点包含以下几点:
1)系统可用性降低
- 系统引入的外部依赖越多,系统稳定性越差。一旦MQ宕机,就会对业务造成影响。
- 如何保证MQ的高可用?
2)系统复杂度提高
- MQ的加入大大增加了系统的复杂度,以前系统间是同步的远程调用,现在是通过MQ进行异步调用。
- 如何保证消息没有被重复消费?怎么处理消息丢失情况?那么保证消息传递的顺序性?
3)一致性问题
A系统处理完业务,通过MQ给B、C、D三个系统发消息数据,如果B系统、C系统处理成功,D系统处理失败。如何保证消息数据处理的一致性?
边栏推荐
- 【js组件】自定义select
- Use, configuration and points for attention of network layer protocol (taking QoS as an example) when using OPNET for network simulation
- 分布式事务解决方案之2PC
- 基于 hugging face 预训练模型的实体识别智能标注方案:生成doccano要求json格式
- 1.AVL树:左右旋-bite
- [reading of the paper] a multi branch hybrid transformer network for channel terminal cell segmentation
- English语法_名词 - 所有格
- Tencent cloud database public cloud market ranks top 2!
- Cve-2021-3156 vulnerability recurrence notes
- MySQL数据库学习(8) -- mysql 内容补充
猜你喜欢
AOSP ~binder communication principle (I) - Overview
[论文阅读] Semi-supervised Left Atrium Segmentation with Mutual Consistency Training
高级程序员必知必会,一文详解MySQL主从同步原理,推荐收藏
High voltage leakage relay bld-20
数字化如何影响工作流程自动化
一条 update 语句的生命经历
[JS component] custom select
Annotation初体验
Under the trend of Micah, orebo and apple homekit, how does zhiting stand out?
利用OPNET进行网络单播(一服务器多客户端)仿真的设计、配置及注意点
随机推荐
Scheduledexecutorservice timer
阿里云的神龙架构是怎么工作的 | 科普图解
什么是依赖注入(DI)
【oracle】简单的日期时间的格式化与排序问题
4. Object mapping Mapster
Initial experience of annotation
利用OPNET进行网络指定源组播(SSM)仿真的设计、配置及注意点
淘宝商品详情页API接口、淘宝商品列表API接口,淘宝商品销量API接口,淘宝APP详情API接口,淘宝详情API接口
Wonderful express | Tencent cloud database June issue
[论文阅读] A Multi-branch Hybrid Transformer Network for Corneal Endothelial Cell Segmentation
做自媒体,有哪些免费下载视频剪辑素材的网站?
In memory, I moved from CSDN to blog park!
Design, configuration and points for attention of network unicast (one server, multiple clients) simulation using OPNET
Talk about mvcc multi version concurrency controller?
Tencent cloud database public cloud market ranks top 2!
JVM (XX) -- performance monitoring and tuning (I) -- Overview
项目经理如何凭借NPDP证书逆袭?看这里
[optimal web page width and its implementation] [recommended collection "
论文阅读【Sensor-Augmented Egocentric-Video Captioning with Dynamic Modal Attention】
5阶多项式轨迹