芹菜功能未调用

时间:2018-07-29 06:51:19

标签: python django python-3.x celery

我尝试用芹菜创建进度条。 不幸的是我的worker函数没有被调用。

def checkconfig_post_new (request):
    job = do_work.delay()
    print ("Work started")
    return HttpResponseRedirect ( reverse ( 'poll_state' ) + '?job=' + job.id )


# this decorator is all that's needed to tell celery this is a worker task
@task()
def do_work():
    for i in range(10):
        sleep(0.1)
        print (i)
        current_task.update_state(state='PROGRESS',
            meta={'current': i, 'total': 10})

打印语句“工作已开始”将永远不会打印出来。而且“ i”将永远不会被打印。

似乎该程序将停止工作。

这是完整的代码:

celery.py

from __future__ import absolute_import, unicode_literals
import os
from celery import Celery

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

app = Celery('devadmin')

# Using a string here means the worker doesn't have to serialize
# the configuration object to child processes.
# - namespace='CELERY' means all celery-related configuration keys
#   should have a `CELERY_` prefix.
app.config_from_object('django.conf:settings', namespace='CELERY')

# Load task modules from all registered Django app configs.
app.autodiscover_tasks()


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

__ init __。py

from __future__ import absolute_import, unicode_literals

# This will make sure the app is always imported when
# Django starts so that shared_task will use this app.
from .celery import app as celery_app

__all__ = ('celery_app',)

views.py

from celery import task, current_task
from celery.result import AsyncResult
from time import sleep

def checkconfig_post_new (request):
    job = do_work.delay()
    print ("Work started")
    return HttpResponseRedirect ( reverse ( 'poll_state' ) + '?job=' + job.id )

tasks.py

@task()
    def do_work():
        for i in range(10):
            sleep(0.1)
            print (i)
            current_task.update_state(state='PROGRESS',
                meta={'current': i, 'total': 10})

1 个答案:

答案 0 :(得分:0)

首先,检查工人的已注册任务(将其启动2倍,有时在第一个打印时将其清空)。

from celery.task.control import  inspect
i = inspect()
i.registered_tasks()

第二,您需要将任务放在tasks.py中,因为autodiscover_tasks搜索此模式。