django celery 定时任务 Crontab 计划格式

news/2024/10/25 10:18:16/

Celery 定时任务教程

Celery 是一个强大的异步任务队列/作业队列基于分布式消息传递的开源项目。它广泛用于处理各种类型的后台任务,例如发送电子邮件、处理图像、数据分析和视频转换等。

本文将介绍如何使用 Celery 实现定时任务,包括:

  • 安装 Celery
  • 配置 Celery
  • 定义定时任务
  • 启动 Celery worker 和 beat

1. 安装 Celery

首先,您需要安装 Celery。可以通过以下命令进行安装:

pip install celery

2. 配置 Celery

django项目主文件夹下(即settings.py同目录)创建一个名为 celery.py 的文件,并添加以下代码:

python">import osfrom django.conf import settingsfrom celery import Celery
from celery.schedules import crontab# Set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'MainConfig.settings')app = Celery('MainConfig')# Using a string here means the worker doesn't have to serialize
# the configuration object to child processes.
# - namespace='CELERY' means all celery-related configuration keys
#   should have a `CELERY_` prefix.
app.config_from_object('django.conf:settings', namespace='CELERY')# Load task modules from all registered Django apps.
app.autodiscover_tasks()# 定时任务配置
app.conf.beat_schedule = {'schedule_task': {'task': 'myapp.tasks.add', # 任务代码所在文件'schedule': crontab(hour='*/3'),  # 每3小时执行一次},
}@app.task(bind=True, ignore_result=True)
def debug_task(self):print(f'Request: {self.request!r}')

这里,我们使用 redis作为消息代理。

crontab示例

例子意义
crontab()每分钟执行一次。
crontab(minute=0, hour=0)每天午夜执行。
crontab(minute=0, hour='*/3')每三小时执行一次:午夜、凌晨 3 点、早上 6 点、早上 9 点、中午、下午 3 点、下午 6 点、晚上 9 点。
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')每十分钟执行一次,但仅限于周四或周五凌晨 3 点至 4 点、下午 5 点至 6 点和晚上 10 点至 11 点之间。
crontab(minute=0, hour='*/2,*/3')每双数小时和每个能被三整除的小时执行。这意味着:除以下时间外的每个小时:凌晨 1 点、凌晨 5 点、早上 7 点、上午 11 点、下午 1 点、下午 5 点、晚上 7 点、晚上 11 点
crontab(minute=0, hour='*/5')执行可被 5 整除的小时。这意味着它是在下午 3 点触发,而不是下午 5 点(因为下午 3 点等于 24 小时制时钟值“15”,可以被 5 整除)。
crontab(minute=0, hour='*/3,8-17')每个能被 3 整除的小时执行一次,办公时间(上午 8 点至下午 5 点)每小时执行一次。
crontab(0, 0, day_of_month='2')每月第二天执行。
crontab(0, 0, day_of_month='2-30/2')在每个双数日执行。
crontab(0, 0, day_of_month='1-7,15-21')在每月的第一周和第三周执行。
crontab(0, 0, day_of_month='11', month_of_year='5')每年五月十一日执行。
crontab(0, 0, month_of_year='*/3')每季度第一个月每天执行。

settings.py相关配置

python">#从环境变量中读取服务网络
REDIS_SERVER_URL = os.environ.get('REDIS_SERVER_URL',"127.0.0.1")
# redis 配置
CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": f"redis://{REDIS_SERVER_URL}:6379/1","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient",}}
}# celery
CELERY_BROKER_URL = f"redis://{REDIS_SERVER_URL}:6379/0"
CELERY_RESULT_BACKEND = f"redis://{REDIS_SERVER_URL}:6379/0"
CELERY_BROKER_CONNECTION_RETRY_ON_STARTUP = True
CELERY_TASK_SERIALIZER = "json"
CELERY_RESULT_SERIALIZER = "json"
CELERY_ACCEPT_CONTENT = ["json"]
CELERY_TIMEZONE = "Asia/Shanghai"
CELERY_ENABLE_UTC = True

django__init___106">在django主项目目录的__init__文件下加入以下代码

python">from .celery import app as celery_app__all__ = ('celery_app',)

3. 定义定时任务

在您的项目中创建一个名为 tasks.py 的文件,并添加以下代码:

python">from celery import shared_task@shared_task
def add(x, y):return x + y

这里,我们定义了一个名为 add 的任务,它接受两个参数 xy 并返回它们的和。

5. 启动 Celery worker 和 beat

使用以下命令启动 Celery worker 和 beat:

celery -A MainConfig worker -l info -P threads
celery -A main beat --loglevel=info

这里,-A 指定当前目录作为工作目录,--loglevel=info 设置日志级别为 info

总结

使用 Celery 实现定时任务非常简单。只需按照上述步骤进行配置,即可轻松实现各种复杂的定时任务。


http://www.ppmy.cn/news/1541807.html

相关文章

智能AI监测系统燃气安全改造方案的背景及应用价值

随着燃气行业的迅速发展和城市化进程的加快,燃气安全管理成为企业运营和城市管理中不可忽视的关键领域。燃气泄漏、管道破损等事故的发生不仅会造成严重的经济损失,还威胁到人民生命财产安全。传统的安全管理方法往往依赖人工巡检和手动监测,…

【CSS进阶】之属性值的计算过程背后的原理

当我们在页面上看见一个元素显示的时候,并附上了丰富的CSS样式,其实这背后经历了一系列复杂的属性计算过程,而最终页面上所呈现的样式则是最终计算的结果,可能并不是我们所编写的样式,这样一来就会在一些场景中造成一些…

【Docker系列】深入理解`docker attach`与`docker exec`

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

使用休眠的方式来解决电脑合盖后偶尔不能正常睡眠的问题

背景描述 用过Windows笔记本电脑的用户应该都偶尔遇到过这样的一个问题,就是电脑直接合上盖后放在包里,按道理来说应该会自动进入睡眠模式,但是等电脑再从包里拿出来时发现电脑很烫,并且已经没电了,似乎并没有进入到休…

分布式---CAPBASE理论

CAP理论 Consistency(一致性):用户访问分布式系统中的任意节点,得到的数据必须一致。即保证任意节点的数据内容一致Availability(可用性):用户访问集群中的任意健康节点,必须能得到…

64页精品PPT | 汽车经销商数据应用解决方案

汽车经销商正面临前所未有的盈利能力挑战。从18年起 ,传统燃油车汽车行业开始步入低速增长阶段 ,卖车已经挣不到钱 ,利润往往来自任务完成的厂家返利;新兴的直营模式的出现 ,冲击了传统授权经销的方式 ,疫情…

LeetCode--验证二叉搜索树--深度优先遍历dfs

一、题目解析 二、算法原理 首先说一下二叉搜索树的概念,二叉搜索树是左子树只包含小于当前节点的数,右子树只包含大于当前节点的数,并且左子树和右子树也必须是二叉搜索树。 由此我们可以得出二叉搜索树的中序遍历的结果是一个有序的序列…

Python数值计算(32)——simpson 1/3积分公式

1. 背景知识 前面我们通过用矩形和梯形的数值算法,近似实现了数值积分,那么,和之前插值类似,是否可以使用多项式来拟合曲线,然后将该多项式作为被积函数求积分呢?当然是可行的,如果以最简单的二…