Периодические задачи с Celery и Django

У меня возникают проблемы с запуском периодических задач с Celery 3.1.8, Django 1.6.1 и RabbitMQ. Я немного запутался с текущей документацией, так как понимаю, что django-celery больше не нужен для запуска Celery с Django. У меня ощущение, что я не правильно запускаю воркер, но после поиска решения на SO и гугления мне нужна помощь. Может ли кто-нибудь указать мне в правильном направлении с этим?

settings.py (не уверен, что мне это нужно, так как у меня есть декоратор @periodic_task в моей задаче)

CELERYBEAT_SCHEDULE = {
    'add-every-30-seconds': {
        'task': 'tasks.send_test_email',
        'schedule': datetime.timedelta(seconds=30)
    },
}

Мое приложение (celery.py)

from __future__ import absolute_import

import os
from celery import Celery
from django.conf import settings

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

app = Celery('app',
             broker='amqp://',
             backend='amqp://',
             include=['app.tasks'])


app.conf.update(
    CELERY_TASK_RESULT_EXPIRES=3600,
    CELERY_TIMEZONE='Europe/Oslo',
    )

if __name__ == '__main__':
    app.start()

# Using a string here means the worker will not have to
# pickle the object when using Windows.
app.config_from_object('django.conf:settings')
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)


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

Периодическая задача (tasks.py)

from __future__ import absolute_import
from celery.task import periodic_task
import datetime

@periodic_task(run_every=datetime.timedelta(minutes=1))
def send_test_email():
    print "This is a periodic task from celery"

В командной строке я запускаю работника:

celery worker -A app -l info
celery beat

person Cliff F    schedule 30.01.2014    source источник
comment
Итак, повозившись еще, я смог заставить его работать. Проблема заключалась в том, как я выполнял worker. Это сработало: сельдерей – лучшее приложение   -  person Cliff F    schedule 31.01.2014
comment
Вы должны добавить это как ответ вместо комментария :)   -  person Jonathan    schedule 09.09.2014


Ответы (1)


Другим решением может быть использование @periodic_task декоратора сельдерея.

from celery.schedules import crontab

@periodic_task(run_every=crontab(minute=0, hour=1))
def my_task():
    print 'my_task'
person t_io    schedule 20.01.2015