Django celery运行多个具有不同队列的工作者

问题描述 投票:0回答:1

我尝试在django中为芹菜配置三个队列/工人。

settings.py

CELERY_BROKER_URL = 'redis://localhost:6379'
CELERY_RESULT_BACKEND = 'redis://localhost:6379'
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TASK_SERIALIZER = 'json'
CELERY_TIMEZONE = 'Europe/Berlin'
CELERY_QUEUES = (
    Queue('manually_task', Exchange('manually_task'), routing_key='manually_task'),
    Queue('periodically_task', Exchange('periodically_task'), routing_key='periodically_task'),
    Queue('firsttime_task', Exchange('firsttime_task'), routing_key='firsttime_task'),
)
CELERY_ROUTES = {
    'api.tasks.manually_task': {
        'queue': 'manually_task',
        'routing_key': 'manually_task',
    },
    'api.tasks.periodically_task': {
        'queue': 'periodically_task',
        'routing_key': 'periodically_task',
    },
    'api.tasks.firsttime_task': {
        'queue': 'firsttime_task',
        'routing_key': 'firsttime_task',
    },
}

我有三个任务,每个任务应该有自己的队列/工作人员。我的任务如下所示:

@shared_task
def manually_task(website_id):
    print("manually_task");
    website = Website.objects.get(pk=website_id)
    x = Proxy(website, "49152")
    x.startproxy()
    x = None


@periodic_task(run_every=(crontab(hour=19, minute=15)), ignore_result=True)
def periodically_task():
    websites = Website.objects.all()

    for website in websites:
        x = Proxy(website, "49153")
        x.startproxy()
        x = None


@shared_task
def firsttime_task(website_id):
    website = Website.objects.get(pk=website_id)
    x = Proxy(website, "49154")
    x.startproxy()
    x = None

现在进行第一次审判,我只雇用一名工人:

celery -A django-proj worker -Q manually_task -n manually_task

我的问题是任务显然没有执行,“ manually_task”没有打印。为什么它不起作用?

django celery django-celery
1个回答
0
投票

基于注释,我建议您从manually_task.apply_async((webseite.pk,), queue='manually_task')之类的视图调用任务时,应提供队列名称,或者像celery中那样启动工作程序时,添加名为celery -A django-proj worker -Q manually_task,celery的默认队列>

© www.soinside.com 2019 - 2024. All rights reserved.