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

当消费者出现异常,很容易引起队列积压,如果一秒钟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进行正常消费;

相关推荐
椰羊~王小美11 分钟前
setScale没传roudingmode,为什么会报错
java
WizLC17 分钟前
【JAVA】JVM类加载器知识笔记
java·jvm·笔记
喝汽水的猫^19 分钟前
Java实现Excel 导出(多 Sheet、复杂格式)
java·excel
毕设源码-朱学姐31 分钟前
【开题答辩全过程】以 基于JavaWeb的疾病查询系统的设计与实现为例,包含答辩的问题和答案
java·eclipse
雨中飘荡的记忆33 分钟前
Java面向对象编程详解
java·开发语言
zhangyifang_00942 分钟前
Spring中的BeanFactory类
java·后端·spring
大学生资源网1 小时前
java毕业设计之面向校园的助力跑腿系统设计与实现源码(源码+文档+数据库)
java·数据库·mysql·毕业设计·源码·springboot
quikai19811 小时前
python练习第六组
java·前端·python
222you1 小时前
线程的常用方法
java·开发语言
是梦终空2 小时前
JAVA毕业设计259—基于Java+Springboot+vue3工单管理系统的设计与实现(源代码+数据库+开题报告)
java·spring boot·vue·毕业设计·课程设计·工单管理系统·源代码