cx372877498 2019-12-12 13:43 采纳率: 0%
浏览 554

rabbitmq的ack非常慢,求答案

图片说明

如图所示,我消费消息的时候没有写业务逻辑,就是直接ack了,理论上这个ack值应该很大的嘛,现在就是上不去。我有两个环境的rabbitmq,一个能达到进200,但另一个就是在20多,就是上不去。请问这个原因大概在哪里?

  • 写回答

1条回答 默认 最新

  • Adger_mi 2024-01-07 18:57
    关注

    调整RabbitMQ的配置参数:可以调整RabbitMQ的一些配置参数来优化ACK的处理速度。例如,可以增加消费者的预取计数(prefetch count),这样消费者可以一次性获取多个消息进行处理,减少ACK的频率。

    使用手动ACK模式:默认情况下,RabbitMQ是自动ACK模式,即消息一旦被消费者接收到就会立即被确认。但是在处理复杂任务时,可以考虑使用手动ACK模式。消费者在处理完消息后手动发送ACK确认,这样可以更好地控制ACK的时机,避免ACK过慢导致内存泄漏。

    增加消费者的数量:如果单个消费者无法处理消息的速度,可以考虑增加消费者的数量,将消息分发给多个消费者并行处理,提高整体的处理速度。

    使用消息的过期时间:可以为消息设置过期时间,超过一定时间未被消费者处理的消息将被自动删除,避免消息堆积导致内存泄漏。

    评论

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题