目录结构

第一步  celery_task 里面的celery文件

import time
from celery import Celery
# celery
from celery.schedules import crontab # 将此文件celery启动 windows celery worker -A celery_task --loglevel=info -P gevent
# 将此文件celery启动 linux celery worker -A celery_task --loglevel=info # 异步任务 Async Task
# 定时任务 Celery Beat
# 消息中间件 Broker
# 任务执行单元 Celery Worker
# 结果存储 Backend # 消息中间件 Broker
broker = 'redis://192.168.10.10'
# 结果存储 Backend
backend = 'redis://192.168.10.10/0' app = Celery('my_task', broker=broker, backend=backend,
include=['celery_task.celery_task_one', 'celery_task.celery_task_two',
]) # 时区
app.conf.timezone = 'Asia/Shanghai'
# 是否使用UTC
app.conf.enable_utc = False # 我要对beat任务生产做一个配置,这个配置的意思就是每10秒执行一次 celery_task.celery_task_one(10,10) app.conf.beat_schedule = {
"each10s_task": {
"task": "celery_task.celery_task_one.add",
"schedule": 30, # 每30秒钟执行一次 # 'schedule': timedelta(seconds=30),
"args": (10, 10)
},
"each1m_task": {
"task": "celery_task.celery_task_two.add_add",
"schedule": crontab(minute='*/1'), # 每一分钟执行一次
"args": (10, 30)
},
"each24hours_task": {
"task": "celery_task.celery_task_two.add",
"schedule": crontab(), # 每一分钟执行一次
"args": (10, 100000)
}
} # 任务结果过期设置 `result_expires=3600' 。默认设置是1天,
app.conf.update(
result_expires=3600,
) # 以上配置完成之后,还有一点非常重要
# 不能直接创建Worker了,因为我们要执行周期任务,所以首先要先有一个任务的生产方
# celery beat -A celery_task
# celery worker -A celery_task -l INFO -P eventlet

第二步 do_task

from celery_task.celery_task_one import add as add1
from celery_task.celery_task_two import add as add2
from celery_task.celery import app from celery.schedules import crontab # 将任务交给Celery的Worker执行
res = add1.delay(1, 3) print(res.id) res = add2.delay(1, 3) print(res.id) """
Celery4
新版的好处是,可以把定时任务和普通的任务一样单独定义了。多了 @app.on_after_configure.connect 这个装饰器,3版本是没有这个装饰器的。
写代码
单独再创建一个py文件,存放定时任务: 链接:https://www.jianshu.com/p/c622f5f5d015
"""

第三步 将所有任务 写在celery_task 下面  'celery_task.celery_task_one', 'celery_task.celery_task_two' 进行调取执行

'celery_task.celery_task_one'

from .celery import app
import time @app.task
def add(x, y):
time.sleep(5)
return x + y
'celery_task.celery_task_two' 
from .celery import app
import time @app.task
def add(x, y):
time.sleep(5)
return x * y @app.task
def add_add(x, y):
time.sleep(5)
return x * y

# 在 celery_task 目录下执行  是用来生产定时任务(app.conf.beat_schedule配置的)

# celery beat -A celery_task

-------------------------------------------------------------

# 在 celery_task 目录下执行,这个的目的是启动 worker , worker是用来执行,生产的任务
# celery worker -A celery_task -l INFO -P eventlet
# 将此文件celery启动   windows   celery worker -A celery_task --loglevel=info -P gevent
# 将此文件celery启动 linux celery worker -A celery_task --loglevel=info
 
# 在  celery_task  目录下执行

celery 简单示例的更多相关文章

  1. Linux下的C Socket编程 -- server端的简单示例

    Linux下的C Socket编程(三) server端的简单示例 经过前面的client端的学习,我们已经知道了如何创建socket,所以接下来就是去绑定他到具体的一个端口上面去. 绑定socket ...

  2. C# 构建XML(简单示例)

    C# 构建XML的简单示例: var pars = new Dictionary<string, string> { {"url","https://www. ...

  3. 根据juery CSS点击一个标签弹出一个遮罩层的简单示例

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  4. ACEXML解析XML文件——简单示例程序

    掌握了ACMXML库解析XML文件的方法后,下面来实现一个比较完整的程序. 定义基本结构 xml文件格式如下 <?xml version="1.0"?> <roo ...

  5. demo工程的清单文件及activity中api代码简单示例

    第一步注册一个账户,并创建一个应用.获取app ID与 app Key. 第二步下载sdk 第三步新建工程,修改清单文件,导入相关的sdk文件及调用相应的api搞定. 3.1 修改清单文件,主要是加入 ...

  6. spring-servlet.xml简单示例

    spring-servlet.xml简单示例 某个项目中的spring-servlet.xml 记下来以后研究用 <!-- springMVC简单配置 --> <?xml versi ...

  7. SignalR 简单示例

    一.什么是 SignalR ASP.NET SignalR is a library for ASP.NET developers that simplifies the process of add ...

  8. Web API 简单示例

    一.RESTful和Web API Representational State Transfer (REST) is a software architecture style consisting ...

  9. celery简单应用

    写作背景介绍 在celery简单入门中已经介绍了写作的背景,这篇文章主要是深入介绍celery的使用技巧.在实际的项目中我们需要明确前后台的分界线,因此我们的celery编写的时候就应该是分成前后台两 ...

随机推荐

  1. 前端实用程序包utils - 开发工作流(一)

    写在前面 早年间有幸在Raychee哥门下当小弟,学到两把刷子.在编程路上,他的很多思想深深影响了我,比如笔者今天要分享的主题.在程序开发中,有个utils包,叫做实用程序包,程序员们会把项目中通用的 ...

  2. 深入探索Android热修复技术原理读书笔记 —— 热修复技术介绍

    1.1 什么是热修复 对于广大的移动开发者而言,发版更新是最为寻常不过的事了.然而,如果你 发现刚发出去的包有紧急的BUG需要修复,那你就必须需要经过下面这样的流程: 这就是传统的更新流程,步骤十分繁 ...

  3. hdu4118

    题意:       给你一颗无向带权树,每个定点上有一个人,问所有定点都不在自己位置上的最长路径总和是多少..   思路:       其实很简单,贪心的想下,既然要求全局最大,那么对于每一条边用的次 ...

  4. POJ 3621 最优比率生成环

    题意:      让你求出一个最优比率生成环. 思路:      又是一个01分化基础题目,直接在jude的时候找出一个sigma(d[i] * x[i])大于等于0的环就行了,我是用SPFA跑最长路 ...

  5. DVWA之Insecure Captcha

    Insecure CAPTCHA Insecure CAPTCHA,意思是不安全的验证码,CAPTCHA是Completely Automated Public Turing Test to Tell ...

  6. TCP的三次握手和四次挥手和UDP协议

    目录 TCP 三次握手 四次挥手 为什么建立连接是三次而断开连接是四次呢? TCP和UDP的区别 TCP数据包的封装 UDP数据包封装 SCTP SYN Flood泛洪攻击 TCP TCP(Trans ...

  7. 网络基础概念(IP、MAC、网关、子网掩码)

    目录 IP地址 MAC地址 网关 子网掩码 反子网掩码 子网掩码 子网划分一: 子网划分二: 子网汇聚 广播域 冲突域 CSMA/CD IP地址 ip地址是用于标识网络中每台设备的标识.目前 IPV4 ...

  8. POJ1698 最大流或者匈牙利

    题意:       一个人他有n个任务,每个任务都有一些限制:  (1)只能在一个星期中指定的日子去做,比如周1 2 6啥的  (2)总工作量有几天,就是一共要工作几天  (3)必须在几周之内完成,就 ...

  9. RHCE7 认证之学习笔记

    -------------------------------------------------------------------------------------------初始化:两台服务器 ...

  10. Dockerfile多阶段构建

    多阶段构建 之前的做法: 在Docker17.05版本之前,构建Docker镜像,通常采用两种方式: 1.全部放入一个Dockerfile 一种方式是将所有的构建过程全都包含在一个Dockerfile ...