MQ系列13:消息大量堆积如何为解决

mq,系列,消息,大量,堆积,如何,解决 · 浏览次数 : 562

小编点评

**MQ系列1:消息中间件执行原理** MQ系列是一个消息中间件,它负责将消息从一个消息生产者传递到多个消息消费者。消息中间件通过提供消息发送和接收服务的中间平台,确保消息的可靠性、顺序性和完整性。 **MQ系列2:消息中间件的技术选型** * **基于内存的消息队列:**例如 Redis、RabbitMQ、Kafka。 * **基于文件系统的消息队列:**例如 Apache Kafka、Apache Pulsar。 * **基于分布式数据库的消息队列:**例如 Apache Cassandra、Rike、HBase。 **MQ系列3:RocketMQ 架构分析** RocketMQ 是一个基于分布式的消息中间件架构。它利用多个broker实例来实现消息传递的功能,并使用消息队列来确保消息的可靠性。 **MQ系列4:NameServer 原理解析** NameServer 是一个消息中间件中用于协调消息交换的服务器。它负责注册消息生产者和消费者,并维护消息队列的配置。 **MQ系列5:RocketMQ 消息的发送模式** RocketMQ 支持两种消息发送模式: * **生产者模式:**生产者将消息发送到多个消费者上。 * **消费者模式:**消费者从一个消息队列中接收消息并处理它们。 **MQ系列6:消息的消费** 消费者从一个消息队列中接收消息并将其处理。消费过程可以分为以下几个步骤: * 消息到达消息队列时,Broker 将消息传递给消费者。 * 消费者从消息队列中接收消息并将其处理。 * 消费者向生产者发送确认信息。 **MQ系列7:消息通信,追求极致性能** MQ系列使用各种技术来追求极致性能,包括: * 使用消息队列来缓存消息,减少网络传输量。 * 使用分布式架构来提高性能。 * 使用消息压缩技术来降低消息传输的成本。 **MQ系列8:数据存储,消息队列的高可用保障** MQ系列使用多种技术来确保消息数据的持久性和消息队列的高可用性: * 使用多个broker实例来实现消息复制,以确保消息的可靠性。 * 使用消息持久化技术来确保消息数据的持久性。 * 使用数据副本技术来确保消息的可靠性。 **MQ系列9:高可用架构分析** MQ系列使用多个broker实例来实现高可用架构。如果某个broker失效,其他broker会接替其工作。 **MQ系列10:如何保证消息幂等性消费** MQ系列可以使用多个消费者来处理消息,确保消息的幂等性。如果某个消费者失效,其他消费者可以处理该消息。 **MQ系列11:如何保证消息可靠性传输** MQ系列使用消息校验和机制来确保消息的可靠性传输。如果消息的校验和验证失败,消息会被重新发送。 **MQ系列12:如何保证消息顺序性** MQ系列使用消息序列号或其他机制来确保消息的顺序性。如果消息的顺序不一致,MQ系列会重新排序它们。 **MQ系列13:总结** MQ系列是一个高度可靠和可扩展的消息中间件,它可以处理高流量的应用程序。MQ系列支持多种消息发送模式和消费模式,并使用多种技术来确保消息的可靠性和性能。

正文

MQ系列1:消息中间件执行原理
MQ系列2:消息中间件的技术选型
MQ系列3:RocketMQ 架构分析
MQ系列4:NameServer 原理解析
MQ系列5:RocketMQ消息的发送模式
MQ系列6:消息的消费
MQ系列7:消息通信,追求极致性能
MQ系列8:数据存储,消息队列的高可用保障
MQ系列9:高可用架构分析
MQ系列10:如何保证消息幂等性消费
MQ系列11:如何保证消息可靠性传输
MQ系列12:如何保证消息顺序性

1 背景

我们在前面两个章节中,介绍了消息组件如何保证可靠性传输和顺序行消费,参考上面系列的11、12章节。

  • 比如在消息生产阶段,如何保证消息发出的稳定性和可靠性;
  • 在消息服务器处理阶段,如何保证消息从生产到发送出去,经过网络传输,再到达Broker服务器并被接收的这整个阶段的可靠性,即如何使用ACK机制来保证消息传递的可靠性;
  • 还有就是消息消费的可靠性,Broker作为消息服务器,消息接收并持久化消息并消费的整个过程的可靠性如何保障。
    对于消息队列组件来说,这几个步骤出现问题,都有可能造成消息队列无法进行正常运行,消息堆积的情况发生。
    另外一种情况可能就是突发的流量峰值,这种一般发生在某种消费促销活动或者各种抢购、竞拍场景中。

2 原因分析

2.1 消息生产(Producer)远超预期

消息的生产的规模远超过原来的预期值,成数倍甚至几十倍的增长,这种产生的原因可能如下:

  1. 比如遇到各种流量冲击的活动:618、双11大促、竞拍、抢购、秒杀业务。(这种需要做好容量预估管理)
  2. 程序缺陷;死循环调用、批量请求、内存泄漏导致的流量飙升问题。(这种需要做好)

image

2.2 消息接收和持久化出现故障

Broker服务器接收消息并持久化出现问题:服务故障、网络延迟、持久化失败等,这种情况一般也比较少见...

2.3 消息消费(Consumer)能力下降致消息堆积

出现原因可能有如下几种:

  • 消费失败时大量重试导致消息堆积。
  • 消费者程序的故障:如 程序死锁,io阻塞等。
  • 消费者资源瓶颈:目前的主流消息队列,单个节点消息收发的性能可以达到万级别甚至10万级+的水平。除非容量预估没有做好,一般不会出现这种问题。即使出现这种问题,通过Scale Out Broker 的实例数也是比较轻松可以解决的。

3 消息堆积的解决方案

根据上面的整理,在遇到消息堆积的时候,先检查下导致堆积的原因,看符合上述的三个原因的哪一个。

  • 消息生产(Producer)远超预期
  • 消息接收和持久化出现故障
  • 消息消费(Consumer)能力下降致消息堆积

找到原因之后,把问题处理完成,然后临时扩容,来处理堆积的消息数据。具体操作步骤如下,参考下面的图:

  • 先分析原因,如果是Consumer或者Broker出现故障要先确保恢复故障;如果是消息消费问题,先修复程序问题。
  • 暂停现有Consumer的消费动作。
  • 临时建立好原先10倍(或者N倍)的queue数量,即新建topic,partition分区是原来的10倍。
  • 写一个程序,这个程序只做简单的转发工作,目的就是将消费积压的消息,均匀的消费到临时扩容好的queue里(这里面有10倍的容量)。
  • Consumer也扩容10倍,对应一个Consumer消费一个临时的Queue。相应的被消费者依赖的业务处理服务也需要对应的扩容,包含缓存、数据库、文件服务等等。
  • 快速消费结束之后,记得恢复原来的消费架构,避免大量资源浪费。

image

总结

本文介绍了消息堆积可能导致的原因,以及基本的处理步骤。大部分消息中间件的健壮性都是非常好的。
业务的不合理使用和扩展一般是主要诱因,所以平时需要多关注业务服务的变化。

与 MQ系列13:消息大量堆积如何为解决相似的内容:

MQ系列13:消息大量堆积如何为解决

[MQ系列1:消息中间件执行原理](https://www.cnblogs.com/wzh2010/p/15888498.html "MQ系列1:消息中间件执行原理") [MQ系列2:消息中间件的技术选型](https://www.cnblogs.com/wzh2010/p/15311174.htm

MQ系列7:消息通信,追求极致性能

MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系列6:消息的消费 1 介绍 前面的章节我学习了 NameServer的原理,消息的生产发送,以及消息

MQ系列8:数据存储,消息队列的高可用保障

MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系列6:消息的消费 MQ系列7:消息通信,追求极致性能 1 介绍 在之前的章节中,我们介绍了消息的发送

MQ系列9:高可用架构分析

MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系列6:消息的消费 MQ系列7:消息通信,追求极致性能 MQ系列8:数据存储,消息队列的高可用保障 1

MQ系列10:如何保证消息幂等性消费

MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系列6:消息的消费 MQ系列7:消息通信,追求极致性能 MQ系列8:数据存储,消息队列的高可用保障 M

MQ系列11:如何保证消息可靠性传输(除夕奉上)

MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系列6:消息的消费 MQ系列7:消息通信,追求极致性能 MQ系列8:数据存储,消息队列的高可用保障 M

MQ系列12:如何保证消息顺序性

[MQ系列1:消息中间件执行原理](https://www.cnblogs.com/wzh2010/p/15888498.html "MQ系列1:消息中间件执行原理") [MQ系列2:消息中间件的技术选型](https://www.cnblogs.com/wzh2010/p/15311174.htm

MQ系列14:MQ如何做到消息延时处理

[MQ系列1:消息中间件执行原理](https://www.cnblogs.com/wzh2010/p/15888498.html "MQ系列1:消息中间件执行原理") [MQ系列2:消息中间件的技术选型](https://www.cnblogs.com/wzh2010/p/15311174.htm

MQ 消息队列 比较

为什么需要消息队列 削峰 业务系统在超高并发场景中,由于后端服务来不及同步处理过多、过快的请求,可能导致请求堵塞,严重时可能由于高负荷拖垮Web服务器。 为了能支持最高峰流量,我们通常采取短平快的方式——直接扩容服务器,增加服务端的吞吐量。 优点是显而易见的,短时间内吞吐量增加了好几倍,甚至数十倍。

MQ消息积压,把我整吐血了

前言 我之前在一家餐饮公司待过两年,每天中午和晚上用餐高峰期,系统的并发量不容小觑。 为了保险起见,公司规定各部门都要在吃饭的时间轮流值班,防止出现线上问题时能够及时处理。 我当时在后厨显示系统团队,该系统属于订单的下游业务。 用户点完菜下单后,订单系统会通过发kafka消息给我们系统,系统读取消息