django-celery简单使用-使用admin新建定时任务

前面说到celery可以进行任务异步处理,celery还有一种Celery的常用模式便是执行定期任务. 执行定期任务时, Celery会通过celerybeat进程来完成. Celerybeat会保持运行, 一旦到了某一定期任务需要执行时, Celerybeat便将其加入到queue中.
配置
settings.py中开启Celery运行定期任务的方式

CELERYBEAT_SCHEDULER = 'djcelery.schedulers.DatabaseScheduler'

然后我们便可以通过django admin的/admin/djcelery/periodictask/添加定期任务

  • 启动redissrc/redis-server
  • 启动celery beatpython manage.py celery beat
  • 启动workerpython 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:
django-celery简单使用-使用admin新建定时任务_第1张图片
选择新增任务:
django-celery简单使用-使用admin新建定时任务_第2张图片
填写对应的信息:
django-celery简单使用-使用admin新建定时任务_第3张图片
设定参数,表示这个参数晕,具体argument和keyword argument不是很清楚分别代表什么,但是第一个是一个list,而且貌似只能是整数:
django-celery简单使用-使用admin新建定时任务_第4张图片

验证
当我们动态的修改admin的任务参数的时候,我们可以看到celery beat 会按照预定的时间间隔或时间点进行处理,在worker这里我们可以看到对应的数据输出:
celery beat:
django-celery简单使用-使用admin新建定时任务_第5张图片
celery worker:
django-celery简单使用-使用admin新建定时任务_第6张图片

你可能感兴趣的:(Web)