定时任务在开发中应用广泛,几乎所有开发人员都会接触到。实现定时任务的方法有很多,其中celery的定时任务功能强大且使用简便,只需安装celery即可。以下是使用celery实现定时任务的详细步骤。

一. 搭建Celery定时任务架构
在项目中合适的位置新建一个定时任务目录
celery_crontab
,在该目录下创建
config.py
、
main.py
和
tasks.py
三个文件,分别用于编写配置代码、定时任务实现代码和任务函数代码。
# 目录结构- celery_crontab - config.py - main.py - tasks.py

二. 编写代码实现定时任务
在
config.py
中编写配置代码
from celery import Celerybroker,使用RabbitMQ
app = Celery('celery_crontab', broker='amqp://guest@localhost//')
或使用Redis
app = Celery('demo', broker='redis://127.0.0.1:6379/15')
在
tasks.py
中编写任务函数代码
from config import app@app.taskdef crontab_func1():print('在此编写任务要实现的代码')
@app.taskdef crontab_func2():print('在此调用实现了定时任务功能的函数或方法')
在
main.py
中调用任务,并实现定时任务功能
from celery.schedules import crontabfrom tasks import *设置定时任务
app.conf.beat_schedule = {
设置定时任务的参数,key可以自定义,见名知义
# value为定时任务的相关参数的字典'contab_func1-every-1-minute': { # 指定要执行的任务函数 'task': 'tasks.crontab_func1', # 设置定时启动的频率,每分钟执行一次任务函数 'schedule': crontab(minute='*/1'), # 传入任务函数的参数,可以是一个列表或元组 # 如果函数没参数则为空列表或空元组 'args': []},'contab_func2-every-day': { 'task': 'tasks.crontab_func2', # 每周一至周五早上8点执行任务函数 'schedule': crontab(minute=0, hour=8, day_of_week=[1, 2, 3, 4, 5]), 'args': []},}
实现定时任务的另一种方式
@app.on_after_configure.connectdef setup_periodic_tasks(sender, **kwargs):
sender.add_periodic_task(间隔时间秒, 任务名.s(参数), name='自定义任务名')
sender.add_periodic_task(10.0, crontab_func1.s(), name='crontab_func1 every 10')sender.add_periodic_task( # 每分钟执行一次 crontab(minute='*/1'), # .s()内传入任务函数需要的参数 crontab_func2.s())在Celery文档中列举了更多任务频率的设置方式,可以直接阅读文档Celery documentation:
http://docs.celeryproject.org/en/latest/userguide/periodic-tasks.html
也可以按住Ctrl左键点击代码中的
crontab,进入源码查看__doc__(文档注释)内容,里面也列举了很多任务频率的设置方法。
三. 启动定时任务
启动定时任务应在
main.py的位置,所以最好到main.py所在目录下执行命令,在其他位置启动时要指定main的路径。'''使用multi方式启动定时任务,celery会自动生成任务子节点和自动创建子进程work为执行任务的进程名字-A main 指定定时任务的启动函数main-l info 指定日志等级为info-B 将celery定时任务设置为后台守护进程,不占用终端--logfile=celerylog.log 指定日志保存的文件名,也可指定路径加文件名'''celery multi start work -A main -l info -B --logfile=celerylog.log
停止定时任务时,将start换成stop
celery multi stop work -A main -l info -B --logfile=celerylog.log
重启定时任务,将start换成restart
celery multi restart work -A main -l info -B --logfile=celerylog.log
在Celery的使用场景中,无论是实现异步任务还是定时任务,基本都会依赖命令来启动和停止任务,因此Celery的命令非常多。了解更多Celery的命令可以到文档中查看。Celery documentation:
https://www.php.cn/link/f82eedc57df33f85b6938f71ed72032f
也可以在终端输入
celery -h查看帮助信息。
Windows Bug:
RuntimeError: This platform does not support detach。在
site-packagesceleryplatforms.py中尝试导入模块“resource”时失败,这个模块不支持Windows,因此定时任务应该部署在Linux系统上。
以上就是Celery实现定时任务crontab的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/183497.html
微信扫一扫
支付宝扫一扫