前面说到celery可以进行任务异步处理,celery还有一种Celery的常用模式便是执行定期任务. 执行定期任务时, Celery会通过celerybeat进程来完成. Celerybeat会保持运行, 一旦到了某一定期任务需要执行时, Celerybeat便将其加入到queue中.
配置
settings.py中开启Celery运行定期任务的方式
CELERYBEAT_SCHEDULER = 'djcelery.schedulers.DatabaseScheduler'
然后我们便可以通过django admin的/admin/djcelery/periodictask/添加定期任务
- 启动redis
src/redis-server
- 启动celery beat
python manage.py celery beat
-
启动worker
python manage.py celery worker --loglevel=info
定时任务:
import time
from celery import task
@task
def sendmail(mail):
print('sending mail to %s...' % mail)
time.sleep(2.0)
print('mail sent.')
print "------------------------------------"
return mail
完成上述操作后,在admin后台进行定时任务配置
主界面我们可以看到可以进行的操作选项,我们选择Periodic tasks:
选择新增任务:
填写对应的信息:
设定参数,表示这个参数晕,具体argument和keyword argument不是很清楚分别代表什么,但是第一个是一个list,而且貌似只能是整数:
验证
当我们动态的修改admin的任务参数的时候,我们可以看到celery beat 会按照预定的时间间隔或时间点进行处理,在worker这里我们可以看到对应的数据输出:
celery beat:
celery worker: