Celery 全局限速器集成冲突重试机制

问题描述

我构建了一个全局速率限制器服务,用于实时检查队列是否达到速率限制。现在我想将速率限制器集成到我的 celery 应用程序(celery + SQS)中,以便:

  1. 每当应用程序收到任务时,它都会查询速率限制器服务以查看队列是否达到速率限制。如果没有,则执行任务,否则将任务放回队列稍后执行

当达到速率限制时,我使用“task.delay()”将任务发送回队列。然而,这与 celery 重试机制混乱:当一个任务被放回队列时,它被认为是一次重试,如果任务有固定的重试次数,则有可能该任务永远不会被执行并达到最大重试次数.

我想知道:

  1. 有没有一种方法可以在不破坏重试机制的情况下延迟接收到的任务?
  2. 或者将全局速率限制器集成到 celery 中的更好解决方案是什么?

非常感谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...