消息队列出现消息积压应该如何处理

当消费者出现异常,很容易引起队列积压,如果一秒钟1000个消息,那么一个小时就是几千万的消息积压,是非常可怕的事情,但是生产线上又有可能会出现;

当消息积压来不及处理,rabbitMQ如果设置了消息过期时间,那么就有可能由于积压无法及时处理而过期,这消息就被丢失了;

解决方法如下:

  • 不建议在生产环境使用数据过期策略,一是数据是否丢失无法控制,二是一旦积压就很有可能丢失;建议数据的处理都有代码来控制;

  • 当出现消息积压时,做法就是临时扩大consumer个数,让消息快速消费,一般都是通过业务逻辑的手段来完成。

rabbitmq解决积压范例

1.修复consumer代码故障,确保consumer逻辑正确可以消费;

2.停止consumer,开启10倍20倍的queue个数;

  • 创建一个临时的consumer程序,消费积压的queue,并把消息写入到扩建的10倍queue中;
  • 再开启10倍20倍的consumer对新的扩充后队列进行消费;
  • 这种做法相当于通过物理资源扩充了10倍来快速消费;

3.当消费完成后,需要恢复原有架构,开启原来的consumer进行正常消费;

kafka解决范例

1.修复consumer代码故障,确保consumer逻辑正确可以消费;

2.停止consumer,新建topic,新建10倍20倍的partition个数;

  • 创建对应原topic的partition个数的临时的consumer程序,消费原来的topic,并把消息写入到扩建的新topic中;

  • 再开启对应新partition个数的consumer对新的topic进行消费;

  • 这种做法相当于通过物理资源扩充了10倍来快速消费;

3.当消费完成后,需要恢复原有架构,开启原来的consumer进行正常消费;

相关推荐
kali-Myon1 小时前
2025春秋杯网络安全联赛冬季赛-day1
java·sql·安全·web安全·ai·php·web
我是咸鱼不闲呀1 小时前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
清水白石0081 小时前
深入解析 LRU 缓存:从 `@lru_cache` 到手动实现的完整指南
java·python·spring·缓存
符哥20081 小时前
C++ 进阶知识点整理
java·开发语言·jvm
Sayuanni%31 小时前
初阶_多线程1(线程含义与关键属性)
java
程序媛徐师姐1 小时前
Java基于微信小程序的模拟考试系统,附源码+文档说明
java·微信小程序·java模拟考试系统小程序·模拟考试微信小程序·模拟考试系统小程序·模拟考试小程序·java模拟考试小程序
疯狂敲代码的老刘2 小时前
JDK 1.6到25 全版本网盘合集 (Windows + Mac + Linux)
java·linux·windows·macos·jdk
夕除2 小时前
js--15
java·jvm·spring
曾经的三心草2 小时前
redis-9-集群
java·redis·mybatis
sun03222 小时前
【架构基础】Spring中的PropertySourcesPlaceholderConfigurer介绍 (并非新知识,比较古老的一种使用方式)
java·spring·架构