Django模型和Celery定期任务

时间:2018-09-12 04:08:43

标签: django django-models celery celerybeat periodic-task

我正在使用Django进行物联网项目,我不喜欢做繁琐的编码,这里的问题是我有一个模型名称,例如:

class Period(models.Model):
      number = models.PositiveIntegerField(primary_key=True)
      start_time = models.TimeField()
      end_time = models.TimeField()

此外,我希望我的芹菜节拍在Period.end_time做些事情,然后添加此代码。代码在mysite / app / tasks.py中。

@app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
    all_periods = Period.objects.all()
    for period in all_periods:
        hour = period.end_time.hour
        minute = period.end_time.minute
        sender.add_periodic_task(
            crontab(hour=hour, minute=minute),
            do_some_thing.s()
        )
@task
def do_some_thing():
      #do_some_thing

这是其他文件:

#mysite/mysite/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', 'smartschool.settings')
app = Celery('smartschool')

# Using a string here means the worker will not have to
# pickle the object when using Windows.
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))

#mysite/mysite/__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']

#mysite/mysite/settings.py ##Celery part.
CELERY_BROKER_URL = 'amqp://'
CELERY_RESULT_BACKEND = 'rpc://'
CELERY_ACCEPT_COTENT = ['application/json']
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TASK_SERIALIZER = 'json'
CELERY_TIMEZONE = 'Asia/Ho_Chi_Minh'
CELERY_IMPORT = ('timetable.tasks')
CELERY_BEAT_SCHEDULE = {
    #'test':
    #{
    #    'task': 'timetable.tasks.hello',
    #    'schedule': 10.0,
    #},
    'system_on':
    {
        'task': 'timetable.tasks.system_on',
        'schedule': crontab(hour=7, minute=0)
    },
    'system_off':
    {
        'task': 'timetable.tasks.system_off',
        'schedule': crontab(hour=17, minute=30)
    },
}

添加到CELERY_SHEDULE_BEAT的方便的定期任务运行良好,但是由add_periodic_task函数添加的任务却没有。英语不是我的母语。请原谅我的帖子中的任何错误。

3 个答案:

答案 0 :(得分:0)

您可以在crontab任务之前使用@periodic_task装饰器,并且在项目运行之后,您应该运行此代码。 celery -A YOURPROJETNAME worker -l -b info

答案 1 :(得分:0)

另一种运行crontab作业的方法。

@task
def my_task():
   //your code 

和您的celery.py文件

app.conf.beat_schedule = {
    'my_task': {
        'task': 'Path.tasks.my_task',
        'schedule': crontab(minute='*/5'),
        'args': []
    },
}

答案 2 :(得分:0)

我想我已经知道了。通过将@ task.on_after_configure.connect更改为@ task.on_after_finalize.connect,add_periodic_task函数起作用了,但是当我有11个Period实例时,仅添加了一个任务!