How can I control the rate at which Spring receives from a queue?(如何控制Spring从队列接收的速率?)
问题描述
我正在使用Spring的消息驱动POJO框架(特别是DefaultMessageListenerContainer)来侦听几个队列和主题。
对于一个特定的队列,需要减慢我排出队列的速度,大约是每五分钟一条消息。消息的实际处理是次秒级操作,但我希望侦听器在消息之间空闲一段时间。
我创建了一些黑客攻击,但它显然不是最优的:我所做的是将最大并发设置为1,并在处理每条消息之后添加Thread.sleep(..)。我希望找到一种方法,在两次尝试接收之间使用DefaultMessageListenerContainer进行等待,而不是让处理程序在想要处理消息的过程中进行等待。
我曾考虑过是否有ScheduledExecutor会有帮助,但我意识到需要在产生任务的地方进行限制。是否有来自DefaultMessageListenerContainer的方法可以重写以完成我想要的内容?
推荐答案
根据队列的提供商,您可以为使用其队列的使用者设置最大速率。
例如,在hornetQ中,您在连接工厂中使用Consumer-max-rate设置此设置。
这篇关于如何控制Spring从队列接收的速率?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何控制Spring从队列接收的速率?
基础教程推荐
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- Struts2 URL 无法访问 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
