celery 简单示例
目录结构
第一步 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 简单示例的更多相关文章
- Linux下的C Socket编程 -- server端的简单示例
Linux下的C Socket编程(三) server端的简单示例 经过前面的client端的学习,我们已经知道了如何创建socket,所以接下来就是去绑定他到具体的一个端口上面去. 绑定socket ...
- C# 构建XML(简单示例)
C# 构建XML的简单示例: var pars = new Dictionary<string, string> { {"url","https://www. ...
- 根据juery CSS点击一个标签弹出一个遮罩层的简单示例
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- ACEXML解析XML文件——简单示例程序
掌握了ACMXML库解析XML文件的方法后,下面来实现一个比较完整的程序. 定义基本结构 xml文件格式如下 <?xml version="1.0"?> <roo ...
- demo工程的清单文件及activity中api代码简单示例
第一步注册一个账户,并创建一个应用.获取app ID与 app Key. 第二步下载sdk 第三步新建工程,修改清单文件,导入相关的sdk文件及调用相应的api搞定. 3.1 修改清单文件,主要是加入 ...
- spring-servlet.xml简单示例
spring-servlet.xml简单示例 某个项目中的spring-servlet.xml 记下来以后研究用 <!-- springMVC简单配置 --> <?xml versi ...
- SignalR 简单示例
一.什么是 SignalR ASP.NET SignalR is a library for ASP.NET developers that simplifies the process of add ...
- Web API 简单示例
一.RESTful和Web API Representational State Transfer (REST) is a software architecture style consisting ...
- celery简单应用
写作背景介绍 在celery简单入门中已经介绍了写作的背景,这篇文章主要是深入介绍celery的使用技巧.在实际的项目中我们需要明确前后台的分界线,因此我们的celery编写的时候就应该是分成前后台两 ...
随机推荐
- 熟知Mysql基本操作
本文是学习 Mysql必知必会 后的笔记 学习之前需要创建一个数据库,然后导入下面两个mysql脚本 create database db1 charset utf8; ############### ...
- php中怎么使用call_user_func动态调用方法
php中可使用call_user_func进行方法的动态调用,可以动态调用普通函数.类方法以及带参数的类方法1.定义一个普通函数getCurrentDate,用于获取今天日期.call_user_fu ...
- Appium命令行启动,提示找不到命令,本地没有appium.cmd文件
安装appium时,直接从github上下载的appium-desktop-windows版本,安装后,从打开桌面端Server,能启动服务,appium-doctor也能正常运行. 但奇怪的地方来了 ...
- SSDT表函数Hook原理
其实 SSDT Hook 的原理是很简单的,我们可以知道在 SSDT 这个数组中呢,保存了系统服务的地址,比如对于 Ring0 下的 NtQuerySystemInformation 这个系统服务的地 ...
- Dalvik模式下System.loadLibrary函数的执行流程分析
本文博客地址:http://blog.csdn.net/qq1084283172/article/details/78212010 Android逆向分析的过程中免不了碰到Android so被加固的 ...
- 缓冲区溢出之栈溢出利用(手动编写无 payload 的 Exploit)
0x01 介绍 Exploit 的英文意思就是利用,它在黑客眼里就是漏洞利用.有漏洞不一定就有Exploit(利用),有Exploit就肯定有漏洞.编写缓冲区溢出的Exploit分为3个方面:漏洞溢出 ...
- 全套AutoCAD版本安装教程及下载地址
1:AutoCAD 2004 安装教程及下载地址 https://mp.weixin.qq.com/s/4So2zmJ6nWu6Z3bSo3W19Q 2:AutoCAD 2005 安装教程及下载地址 ...
- linux 发送邮件
参考资料:https://www.cnblogs.com/imweihao/p/7250500.html https://blog.csdn.net/liang19890820/article/det ...
- Js的变量、作用域与内存
变量.作用域与内存 1 .原始值与引用值 Undefined.Null.Boolean.Number. String和Symbol.保存原始值的变量是按值(by value)访问的 引用值是保存在内存 ...
- c语言编程学习之字符串
字符串字面量与字符变量 1.字符串字面量 字符串字面量是一对双引号括起来的字符序列.当c语言编译器在程序中遇到长度为n的字符串字面量时,它会为字符串字面量分配长度为n+1的内存空间.这块内存空间用来存 ...