Celery定时任务细讲

Celery定时任务细讲

一.目录结构

任务所在目录
    ├── celery_task # celery包 如果celery_task只是建了普通文件夹__init__可以没有,如果是包一定要有
    │   ├── __init__.py # 包文件 看情况要不要存在
    │   ├── celery.py   # celery连接和配置相关文件,且名字必须交celery.py,其实也不是必须的不然你指令可能要修改
    │   └── tasks.py    # 所有任务函数

二.配置

celery.py

from celery import Celery

#创建一个Celery对象
broker = 'redis://127.0.0.1:6379/2'  #任务放在用redis://ip:端口/第几个数据库
backend = 'redis://127.0.0.1:6379/3' #任务结果放在
include = ['celery_task.tasks',]    #任务所在目录
app = Celery(broker=broker, backend=backend, include=include)

app.conf.timezone = 'Asia/Shanghai'  #配置时区
app.conf.enable_utc = False      # 是否使用UTC

from datetime import timedelta
from celery.schedules import crontab
app.conf.beat_schedule = {
    #任务名称自定义可随意
    'get_banner-task': {
        'task': 'celery_task.tasks.get_baidu_info',#任务所在路径且指定哪个任务
        'schedule': crontab(hour=3,minute=0),  #定时任务相关
    },
}

celery.py

from .celery import app
import requests
@app.task  #一定要加装饰器
def get_baidu_info():
    response = requests.get(https://www.baidu.com/')
    return response.text

三.配置参数

配置参数的方式

方式一

app.conf.参数名称=参数值

方法二

app.conf.update(
    参数名称=参数值,
    参数名称=参数值
)

方法三

导入配置文件

app.config_from_object('配置文件路径')

配置文件

参数名称=参数值
参数名称=参数值

一.时区配置

常用中国

app.conf.timezone = 'Asia/Shanghai'
app.conf.enable_utc = False
#也可以直接设置
app.conf.timezone = 'Asia/Shanghai' 

国际时间

app.conf.enable_utc = True
app.conf.timezone = 'Europe/London'
#也可以直接设置
app.conf.timezone = 'Europe/London'

二.beat_schedule

  • task: 指定任务的名字
  • schedule : 设定任务的调度方式,可以是一个表示秒的整数,也可以是一个 timedelta 对象,或者是一个 crontab 对象(后面介绍),总之就是设定任务如何重复执行
  • args: 任务的位置参数以列表的形式
  • kwargs:任务的关键字参数,以字典的形式
  • options:所有 apply_async 所支持的参数

timedelta 对象

from datetime import timedelta

 'schedule': timedelta(seconds=3), #每三秒 执行一次 其他想想就知道啦
  #具体有啥参数我也不想列举了你ctrl+左键进入timedelta源码自己看就知道啦

crontab 对象

#schedule配置举例
from celery.schedules import crontab
# 每分钟执行一次
crontab()

# 每天凌晨十二点执行
crontab(minute=0, hour=0)

# 每十五分钟执行一次
crontab(minute='*/15')

# 每周日的每一分钟执行一次
crontab(minute='*',hour='*', day_of_week='sun')

# 每周三,五的三点,七点和二十二点没十分钟执行一次
crontab(minute='*/10',hour='3,17,22', day_of_week='thu,fri')

原文地址:https://www.cnblogs.com/pythonywy/p/11665791.html

时间: 2024-11-10 00:54:56

Celery定时任务细讲的相关文章

JavaScript基础细讲

JavaScript基础细讲 JavaScript语言的前身叫作Livescript.自从Sun公司推出著名的Java语言之后,Netscape公司引进了Sun公司有关Java的程序概念,将自己原有的Livescript 重新进行设计,并改名为JavaScript. JavaScript是一种基于对象和事件驱动并具有安全性能的脚本语言,有了JavaScript,可使网页变得生动.使用它的目的是与HTML超文本标识语言.Java 脚本语言一起实现在一个网页中链接多个对象,与网络客户交互作用,从而可

SQL内置函数细讲

一.伪表.系统内置的只有一行一列数据的表.常用来执行函数. select 函数名 from dual 注:以下所有函数为了方便理解均用 伪表 做为事例! 二. 时间函数 1.sysdate:获取数据库系统的当前时间 例:select sysdate from dual 我们就会获取到当前系统的时间 2.add_months:对日期的月份进行加减 select add_months(日期, 数值) from dual 在这里的数值是必须要写的,如果不想对日期进行加减我们可以把数值写成0! 例:se

利用django admin后台配置celery定时任务

1.安装djcelery pip install django-celery 2.在Django项目setting配置 A.配置djcelery # CELERY STUFF import djcelery djcelery.setup_loader() BROKER_URL = 'redis://localhost:6379' CELERYBEAT_SCHEDULER = 'djcelery.schedulers.DatabaseScheduler' # 定时任务 CELERY_RESULT_

Linux先知和几个常用命令细讲

Linux先知: Linux历史: 关于这个我就不再多说了,其实是一个很有意思的故事串,网上找下一大堆. 类Unix系统目录结构: ubuntu没有盘符这个概念,只有一个根目录/,所有文件都在它下面 Linux 目录 /:根目录,一般根目录下只存放目录,在Linux下有且只有一个根目录.所有的东西都是从这里开始.当你在终端里输入"/home",你其实是在告诉电脑,先从/(根目录)开始,再进入到home目录 /bin: /usr/bin: 可执行二进制文件的目录,如常用的命令ls.tar

将celery定时任务设置为根据本地时区触发

默认celery的时区为UTC,如果要在django项目中将celery定时任务配置为根据本地时区触发,则需要修改 在setttings.py 添加以下任意一行: # celery 相关配置 CELERY_TIMEZONE = 'Asia/Shanghai' CELERY_ENABLE_UTC = False 原文地址:https://www.cnblogs.com/linyihai/p/10140936.html

celery 定时任务

1 基本概念 使用 Celery 实现定时任务的步骤: (1) 创建一个 Celery 实例 (2) 配置文件中配置任务 ,发布任务 celery A xxx beat (3) 启动 Celery Worker (4) 存储结果 使用 Celery 实现异步任务的步骤: (1) 创建一个 Celery 实例 (2) 启动 Celery Worker ,通过delay() 或 apply_async()(delay 方法封装了 apply_async, apply_async支持更多的参数 ) 将

celery 定时任务,使用crontab表达式不执行(版本4.3.x)

celery 定时任务,使用crontab表达式不执行(版本4.3.x) 在使用celery 执行定时任务时,发现任务不会执行,schedule设置如下: 经测试,如果去掉hour,则任务每分钟都会执行,说明是hour的问题,那只有是时区的问题了. 遂将hour改为UTC的时间,发现任务可以执行,说明celery使用的是UTC时区,但我设置的时区如下: CELERY_TIMEZONE='Asia/Shanghai' CELERY_ENABLE_UTC=True 注意添加任务的时候使用utc时间,

[转帖]JProfiler远程监控Linux上Tomcat的安装过程细讲(步骤非常详细!!!)

JProfiler远程监控Linux上Tomcat的安装过程细讲(步骤非常详细!!!) https://www.cnblogs.com/yjd_hycf_space/p/7727757.html 原文地址:https://www.cnblogs.com/jinanxiaolaohu/p/12115262.html

Django-如何写好一个celery定时任务

1.首先在项目同名目录下建一个celery.py from __future__ import absolute_import import os from celery import Celery from datetime import timedelta from kombu import Queue # set the default Django settings module for the 'celery' program. os.environ.setdefault('DJANG