13

我试图为 Celery 设置 Amazon SQS,我有以下配置:

BROKER_BACKEND = "SQS"
BROKER_TRANSPORT_OPTIONS = {
    'region': 'us-east-1',
}
AWS_ACCESS_KEY_ID = # access id
AWS_SECRET_ACCESS_KEY = # secret access key
os.environ.setdefault("AWS_ACCESS_KEY_ID", AWS_ACCESS_KEY_ID)
os.environ.setdefault("AWS_SECRET_ACCESS_KEY", AWS_SECRET_ACCESS_KEY)

BROKER_URL = 'sqs://'

CELERY_IMPORTS = ("tasks", )
CELERY_TASK_RESULT_EXPIRES = 300

CELERY_DEFAULT_QUEUE = #queue name
CELERY_DEFAULT_EXCHANGE = CELERY_DEFAULT_QUEUE
CELERY_DEFAULT_EXCHANGE_TYPE = CELERY_DEFAULT_QUEUE
CELERY_DEFAULT_ROUTING_KEY = CELERY_DEFAULT_QUEUE
CELERY_QUEUES = {
    CELERY_DEFAULT_QUEUE: {
        'exchange': CELERY_DEFAULT_QUEUE,
        'binding_key': CELERY_DEFAULT_QUEUE,
    }
}

在我对 AWS 账户的 SQS 配置中,我有一个名为CELERY_DEFAULT_QUEUE. 当我在本地运行它时,一切正常……但由于某种原因,它在 SQS 上创建了另一个名为 format 的队列<user_id>-celery-pidbox。像这样的东西:MyUser-MacBook-Pro-local-celery-pidbox

这是正常的吗?当我创建了一个指定名称的队列时,为什么还要创建另一个队列?否则,它的工作,不确定是否需要其他队列或我错过了什么?任何帮助表示赞赏,我在文档中找不到这个。

编辑

原来这是正常的。出于某种原因 django-celery 这样做,它为您访问要访问的队列的每个框创建一个队列。他们将在未来的版本中解决此问题。如果有人知道如何临时解决这个问题,请告诉我,谢谢!

4

2 回答 2

5

这实际上是一个很好的行为,因此您可以监控哪些实例(IP 或本地名称)正在访问您的 SQS 帐户。这只是一个请求,因此不会花费您任何费用。

于 2013-03-08T19:07:29.227 回答
3

你需要设置这些:

 CELERY_ENABLE_REMOTE_CONTROL = False 
 CELERY_SEND_EVENTS = False

禁用它。

于 2017-08-08T17:20:40.040 回答