把Celery集成到Django里之计划任务

实验环境和前期设置接上篇把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里查看执行的结果。


除非标明,否则皆为<IT民工の在日生活 - 神户印象>原创之作,转载必须以明文链接标明出处。
本文链接:https://www.lifeinjp.net/share/501

发表评论