一条命令启动worker和beat
celery -B -A celery_task worker -l INFO
定时任务配置信息属性:
task:要执行的任务名字
schedule :执行的频率 。
args:位置参数 (list 或 tuple).
kwargs:键值参数 (dict).
options:执行选项 (dict).
这可以是任何被apply_async()支持的参数。
relative:如果 relative 是 true ,时间表“由时钟时间”安排,意味着 频率近似到最近的秒,分钟,小时或天,这取决于时间差中的时间间隔。
默认relative是false,频率不会近似,会相对于celery的启动时间。
crontab参数:
crontab()实例化的时候没设置任何参数,都是使用默认值,表示1分钟。crontab常用有5个参数:
minute:分钟,范围0-59;
hour:小时,范围0-23;
day_of_week:星期几,范围0-6。以星期天为开始,即0为星期天。这个星期几还可以使用英文缩写表示,例如“sun”表示星期天;
day_of_month:每月第几号,范围1-31;
month_of_year:月份,范围1-12。
注意:
默认值都是"*"星号,代表任意时刻
举例:
crontab() 每分钟执行
crontab(minute=15) 每小时的15分时刻执行一次任务
crontab(minute=0, hour=0) 每天0点0分时刻执行任务
crontab(minute='59',hour='11') 每天的11点59分执行一次任务
crontab(minute='0,30')
0分和30分执行一次任务,逗号是表示多个表达式or逻辑关系
crontab(hour='9-12,20')
其他举例:
crontab(minute=0, hour=0) 每天午夜执行
crontab(minute=0, hour=’*/3’) 每三个小时执行: 午夜, 3am, 6am, 9am, 正午, 3pm, 6pm, 9pm.
crontab(minute=0,hour=’0,3,6,9,12,15,18,21’) 同上
crontab(minute=’*/15’) 每15分钟执行
crontab(day_of_week=’sunday’) 星期日每分钟
crontab(minute=’‘,hour=’‘, day_of_week=’sun’) 同上
crontab(minute=’*/10’,hour=’3,17,22’, day_of_week=’thu,fri’) 每10分钟执行,仅限于周六日3-4 am, 5-6 pm, and 10-11 pm
crontab(minute=0, hour=’/2,/3’) 偶数小时或者能被3整除的小时数执行
crontab(minute=0, hour=’*/5’) 被5整除的小时数,如3pm
crontab(minute=0, hour=’*/3,8-17’) 8am-5pm能被3整除的
crontab(0, 0, day_of_month=’2’) 每月第2天
crontab(0, 0,day_of_month=’2-30/3’) 每偶数天
crontab(0, 0,day_of_month=’1-7,15-21’) 每月1和3周
crontab(0, 0, day_of_month=’11’,month_of_year=’5’) 每年5月11日
crontab(0, 0,month_of_year=’*/3’) 每个季度第1月