gpt4 book ai didi

python - Django + Celery + SQS 设置。 Celery 通过 ampq 连接到默认的 RabbitMQ

转载 作者:行者123 更新时间:2023-11-30 22:46:16 25 4
gpt4 key购买 nike

我正在尝试将 Amazon SQS 设置为 Django 应用程序中 Celery 的默认消息代理。 Celery 工作线程正在启​​动,但代理设置为默认 RabbitMQ。您可以在下面找到我的工作人员的输出。

这是我在项目中的一些配置。我的 celery.py 看起来像:

from __future__ import absolute_import
import os
from celery import Celery

# set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'dance.settings')

app = Celery('dance')

app.config_from_object('django.conf:settings', namespace='CELERY')
app.autodiscover_tasks()

@app.task(bind=True)
def debug_task(self):
print('Request: {0!r}'.format(self.request))

负责设置代理 URL 的 Django celery 设置的基本部分是:

BROKER_URL = 'sqs://{}:{}@'.format(AWS_ACCESS_KEY_ID, quote(AWS_SECRET_ACCESS_KEY, safe=''))
BROKER_TRANSPORT_OPTIONS = {
'region': 'eu-west-1',
'polling_interval': 3,
'visibility_timeout': 300,
'queue_name_prefix':'dev-celery-',
}

当我尝试在虚拟环境中启动工作程序时:

celery -A dance worker -l info

我收到以下输出:

 -------------- celery@universe v4.0.0 (latentcall)
---- **** -----
--- * *** * -- Linux-4.8.0-28-generic-x86_64-with-debian-stretch-sid 2016-12-02 14:20:40
-- * - **** ---
- ** ---------- [config]
- ** ---------- .> app: dance:0x7fdc592ca9e8
- ** ---------- .> transport: amqp://guest:**@localhost:5672//
- ** ---------- .> results:
- *** --- * --- .> concurrency: 8 (prefork)
-- ******* ---- .> task events: OFF (enable -E to monitor tasks in this worker)
--- ***** -----
-------------- [queues]
.> celery exchange=celery(direct) key=celery


[tasks]
...
task1
task2
...

列出了任务,所以我猜 Celery 获取并处理相关的 Django 设置。如果将设置从 SQS 切换到 Redis,我也会遇到同样的问题。

据我从阅读教程中了解到,工作人员的输出应该类似于。

- ** ---------- .> transport:   sqs://*redacted*:**@localhost//
- ** ---------- .> results: djcelery.backends.database:DatabaseBackend

此外,我没有使用djcelery,因为它已经过时了。相反,我使用 django_celery_results ,因为它是 Celery 设置页面上推荐的。最后的输出只是来自业余项目的猜测。

最佳答案

我发现的唯一可能的解决方案是显式指定代理和数据库后端。

对我来说,这看起来很奇怪,因为 Django settings.py 中的设置没有完全加载,或者可能我错过了一些东西,否则这是 Celery 的错误。

app = Celery('dance', broker='sqs://', backend='django-db')

真正的解决方案:

这就是我遇到问题的原因:

Django 中的所有 Celery 变量都应以 CELERY 开头,因此我必须使用 CELERY_BROKER_URL 和 CELERY_BROKER_TRANSPORT_OPTIONS,而不是使用 BROKER_URL 和 BROKER_TRANSPORT_OPTIONS

关于python - Django + Celery + SQS 设置。 Celery 通过 ampq 连接到默认的 RabbitMQ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40931345/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com