消息中间件MQ(介绍)

什么是消息中间件

消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型,它可以在分布式环境下扩展进程间的通信。对于消息中间件,常见的角色大致也就有Producer(生产者)、Consumer(消费者)。

消息队列中间件是分布式系统中重要的组件,主要解决应用解耦,异步消息,流量削锋等问题,实现高性能,高可用,可伸缩和最终一致性架构。

常见的消息中间件MQ

常见的消息中间件产品:

  • ActiveMQ :出现最早、最为稳定的、但是支持的并发最少
    ActiveMQ 是Apache出品,最流行的,最早的、能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现。
  • RabbitMQ
    AMQP协议的领导实现,支持多种场景。淘宝的MySQL集群内部有使用它进行通讯,OpenStack开源云平台的通信组件,最先在金融行业得到运用。我们在本次课程中介绍 RabbitMQ的使用。
  • ZeroMQ:史上最快的消息队列系统
  • Kafka 高吞吐:支持高并发大数据
    Apache下的一个子项目 。特点:高吞吐,在一台普通的服务器上既可以达到10W/s的吞吐速率;完全的分布式系统。适合处理海量数据。
  • RocketMQ 阿里巴巴

应用场景

异步处理应用解耦流量削锋消息通讯四个场景。

1.异步处理

场景说明:用户注册后,需要发注册邮件和注册短信。
传统的做法有两种 :1.串行的方式;2.并行方式
1、串行方式:将注册信息写入数据库成功后,发送注册邮件,再发送注册短信。以上三个任务全部完成后,返回给客户端。
在这里插入图片描述
2、并行方式:将注册信息写入数据库成功后,发送注册邮件的同时,发送注册短信。以上三个任务完成后,返回给客户端。与串行的差别是,并行的方式可以提高处理的时间
在这里插入图片描述
假设三个业务节点每个使用50毫秒钟,不考虑网络等其他开销,则串行方式的时间是150毫秒,并行的时间可能是100毫秒。
因为CPU在单位时间内处理的请求数是一定的,假设CPU1秒内吞吐量是100次。则串行方式1秒内CPU可处理的请求量是7次(1000/150)。并行方式处理的请求量是10次(1000/100)
问题:传统的方式系统的性能(并发量,吞吐量,响应时间)会有瓶颈。如何解决这个问题呢?
解决:引入消息队列,将不是必须的业务逻辑,异步处理。
在这里插入图片描述
按照以上约定,用户的响应时间相当于是注册信息写入数据库的时间,也就是50毫秒。注册邮件,发送短信写入消息队列后,直接返回,因此写入消息队列的速度很快,基本可以忽略,因此用户的响应时间可能是50毫秒。因此架构改变后,系统的吞吐量提高到每秒20 QPS。比串行提高了3倍,比并行提高了两倍

2.应用解耦

上面的应用也体现了解耦合

3.流量消峰

流量削锋也是消息队列中的常用场景,一般在秒杀或活动中使用广泛。应用场景:秒杀活动,一般会因为流量过大,导致流量暴增,应用挂掉。为解决这个问题,一般需要在应用前端加入消息队列。
通过加入消息队列完成如下功能:

  1. 可以控制活动的人数
  2. 可以缓解短时间内高流量压垮应用
    在这里插入图片描述
    用户的请求,服务器接收后,首先写入消息队列。假如消息队列长度超过最大数量,则直接抛弃用户请求或跳转到错误页面。秒杀业务根据消息队列中的请求信息,再做后续处理
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
引用\[1\]:MQ是指消息中间件,是一种面向消息的中间件,通过高效可靠的消息传递机制与平台无关的数据交流,并基于数据通信来进行分布式系统的集成。它提供了消息传递和消息排队模型,在分布式环境下实现了应用解耦、弹性伸缩、冗余存储、流量削峰、异步通信、数据同步等功能。\[1\] 引用\[2\]:主从模式是MQ中的一种消息传递模式。在主从模式中,消息发送者将消息发送到一个虚拟的通道(主题或队列),而消息接收者则订阅或监听该通道。消息可能会被转发给一个或多个消息接收者,这些接收者无需对发送者做出同步回应。整个过程是异步的,发送者不关心接收者如何处理消息或是否处理完毕。\[2\] 因此,主从模式消息中间件MQ是一种通过消息传递机制实现系统间异步通信的中间件。在该模式下,消息发送者将消息发送到一个通道,而消息接收者订阅或监听该通道,接收并处理消息。这种模式可以提高系统的吞吐量,实现应用解耦,削峰填谷,以及实现日志处理和消息通讯等功能。 #### 引用[.reference_title] - *1* *2* [微服务 消息中间件MQ](https://blog.csdn.net/m0_37583655/article/details/122575034)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java消息中间件MQ面试题重点汇总](https://blog.csdn.net/fegus/article/details/125671153)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值