实验环境和前期设置接上篇把Celery集成到Django里之异步任务。
第一步,为了让计划任务执行的时间符合我们的预期,我们先在myproj/myproj/settings.py添加一个Celery需要的时区变量:
CELERY_TIMEZONE = "Asia/Shanghai"
第二步,然后我们在myproj/app1/tasks.py里添加计划任务,根据Celery官方文档,添加计划任务有以下两种方式:
import time
from celery import shared_task
from myproj import myproj_celery #myproj/myproj/__init__.py(参见上一篇)
from celery.schedules import crontab
@shared_task
def add(x, y):
#为了看到异步效果,我们睡一分钟再执行
time.sleep(60)
return x + y
#第一种 计划任务
@myproj_celery.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
#每十秒执行一次异步任务add(10,20)
sender.add_periodic_task(10.0, add.s(10, 20), name='call task add(10,20) every 10 seconds')
#每个周一早上7点半执行异步任务add(20, 30)
sender.add_periodic_task(
crontab(hour=7, minute=30, day_of_week=1),
add.s(20, 30),
)
#第二种 计划任务
myproj_celery.conf.beat_schedule = {
#每十秒执行一次异步任务add(10,20)
'add-every-10-seconds': { #计划任务名,随便取
'task': 'app1.tasks.add', #注意,这里要填写app名.任务文件名.任务名
'schedule': 10.0,
'args': (10, 20)
},
#每个周一早上7点半执行异步任务add(20, 30)
'monday-morning-730': { #计划任务名,随便取
'task': 'app1.tasks.add', #注意,这里要填写app名.任务文件名.任务名
'schedule': crontab(hour=7, minute=30, day_of_week=1),
'args': (20, 30)
},
}
第三步,启动计划任务调度器(celery beat)
[root@myproj ~]# celery -A myproj beat -l INFO
好了,你设置的计划任务就会按时执行了,你可以去redis里查看执行的结果。