celery 计划任务使用
流程: 用户提交任务 --- > Celery --- > Broker 中间商(可以是数据库,redis) ---> 最后让celery 中的 worker 执行任务 1 单独使用:
目录结构:
celery_worker.py 文件
#-*- coding:utf-8 -*-
from celery import Celery
import time
app = Celery('tasks', #tasks是app 名字
broker='redis://127.0.0.1:6379/0', #密码方式redis://xxxx@127.0.0.1:6379/0
backend='redis://127.0.0.1:6379/0' #密码方式redis://xxxx@127.0.0.1:6379/0#密码方式redis://xxxx@127.0.0.1:6379/0
) @app.task
def add(x,y): #运行的任务
print("success.......",x,y)
time.sleep(30)
return x + y
celery_client.py 文件
#-*- coding:utf-8 -*-
from celery_work import add
t1 = add.delay(1,2) #提交任务执行 #print(t1.get()) #获取任务执行的结果
#print(t1.get(timeout=1)) #设置当前获取超时时间
#print(t1.ready()) #查看任务是否执行完成,Ture执行完成
1 进入单独使用目录里面启动worker
celery -A celery_work worker -l info -P eventlet #celery_work 为当前py文件名 2 项目使用
目录结构:

新建一个 tasks_worker 目录 里面创建 celery.py这是Broker myTasks_1.py任务1 myTasks_2.py任务2 三个文件
celery.py (文件名必须这样命令)
celery.py文件
#-*- coding:utf-8 -*-
from __future__ import absolute_import, unicode_literals
from celery import Celery #__future__ 表示将相对路径转换为绝对路径 from celery 导入是从python 包里面的绝对路劲导入Celery app = Celery('pro',
broker='redis://127.0.0.1:6379/0',
backend='redis://127.0.0.1:6379/0',
include=(['tasks_worker.myTasks_1','tasks_worker.myTasks_2']) #存任务的文件,tasks_worker当前目录名字是myTasks_1,可以存多个,tasks必须要有这个py文件 tasks_2是一个py文件
) app.conf.update(
result_expires = 3600, #任务结果保存时间 一个小时
) if __name__ == "__main__":
app.start()
myTasks_1.py文件
#-*- coding:utf-8 -*-
# 将相对路径转换为绝对路径
from __future__ import absolute_import, unicode_literals
from .celery import app #获取当前目录中的celery的app @app.task
def add(x,y):
print("success.......",x,y)
return x + y
myTasks_2.py文件
#-*- coding:utf-8 -*-
# 将相对路径转换为绝对路径
from __future__ import absolute_import, unicode_literals
from .celery import app #获取当前目录中的celery的app @app.task
def add(x,y):
print("success.......",x,y)
return (x * y)
项目使用目录下面新建一个 执行任务.py
#-*- coding:utf-8 -*- from tasks_worker.myTasks_1 import add as add_1
from tasks_worker.myTasks_2 import add as add_2 t1 = add_1.delay(1,2)
print(t1.get()) t2 = add_2.delay(1,2)
print(t2.get())
进入项目使用目录
1 里面必须命名为celery.py
2 myTasks_1.py 为任务1
3 myTasks_2.py 为任务2
启动 celery -A tasks_worker worker -l debug -P eventlet #tasks_worker是项目使用下面的tasks_worker文件夹
3定时任务(重点)
目录结构:

celery.py文件
#-*- coding:utf-8 -*-
from __future__ import absolute_import, unicode_literals
from celery import Celery #__future__ 表示将相对路径转换为绝对路径 from celery 导入是从python 包里面的绝对路劲导入Celery app = Celery('pro',
broker='redis://127.0.0.1:6379/0',
backend='redis://127.0.0.1:6379/0',
include=(['timing.celery_Tasks']) #存任务的文件,tasks_worker当前目录名字是myTasks_1,可以存多个,tasks必须要有这个py文件 tasks_2是一个py文件
) app.conf.update(
result_expires = 3600, #任务结果保存时间 一个小时
) if __name__ == "__main__":
app.start()
celery_Tasks.py
#-*- coding:utf-8 -*-
from __future__ import absolute_import, unicode_literals #__future__ 表示将相对路径转换为绝对路径 from celery 导入是从python 包里面的绝对路劲导入Celery
from .celery import app
from celery.schedules import crontab
#第一种写法
# @app.on_after_configure.connect
# def tasks_p(sender,**kwargs):
# #sender.add_periodic_task(10.0,test.s("hello"),name="test"), #每秒执行下test函数 要带.s 格式就是整要求的
#
# #sender.add_periodic_task(20.0, test.s("world"), name="test" , expires=10),
#
# sender.add_periodic_task(
# crontab(hour=16, minute=13,),
# test.s(123),
# )
# #修改app配置文件第二种写法
app.conf.beat_schedule = {
'add-every-10s':{
'task': "timing.celery_Tasks.test", #路劲要写全 timing目录下面的 celert_Tasks 里面的 test方法
'schedule': 10.0, #每10秒执行上面的任务
'args':(10,) #传递这个参数到test里面
}, 'add-every-20s': {
'task': "timing.celery_Tasks.test",
'schedule': 20.0,
'args': (20,)
},
'add-every-cron': {
'task': "timing.celery_Tasks.test",
'schedule': crontab(hour=16, minute=26, day_of_week=1),
'args': ("开始.....................................................",)
} } app.conf.timezone = 'Asia/Shanghai' #设置时区不然会按utc时间执行
@app.task
def test(arg,):
print("run....",arg)
进入定时目录
启动worker : celery -A timing worker -l debug -P eventlet
启动beat : celery -A timing.celery_Tasks beat -l debug
celery 计划任务使用的更多相关文章
- celery 分布式异步任务框架(celery简单使用、celery多任务结构、celery定时任务、celery计划任务、celery在Django项目中使用Python脚本调用Django环境)
一.celery简介: Celery 是一个强大的 分布式任务队列 的 异步处理框架,它可以让任务的执行完全脱离主程序,甚至可以被分配到其他主机上运行.我们通常使用它来实现异步任务(async tas ...
- Celery配置实践笔记
说点什么: 整理下工作中配置celery的一些实践,写在这里,一方面是备忘,另外一方面是整理成文档给其他同事使用. 演示用的项目,同时也发布在Github上: https://github.com/b ...
- django -- Celery实现异步任务
1. 环境 python==2.7 djang==1.11.2 # 1.8, 1.9, 1.10应该都没问题 celery-with-redis==3.0 # 需要用到redis作为中间人服务(Bro ...
- django —— Celery实现异步和定时任务
1. 环境 python==2.7 djang==1.11.2 # 1.8, 1.9, 1.10应该都没问题 celery-with-redis==3.0 # 需要用到redis作为中间人服务(Bro ...
- Django + Celery 实现动态配置定时任务
哈喽,今天给大家分享一篇Django+Celery实现动态配置定时任务,因为最近也是无意间看到一位大佬关于这块的文章,然后自己觉得不错,也想学习写一下,然后最终实现功能是在前端页面统一管理计划任务,大 ...
- 基于 Django 2.0.4 的 djcelery 配置
Django Celery 配置实践 所需环境 python 3.5.2 rabbitmq 安装所需的包 pip install -r requirements.txt QuickStart 创建Dj ...
- Celery学习---Celery 与django结合实现计划任务功能
项目的目录结构: 项目前提: 安装并启动Redis 安装Django和Celery的定时任务插件 安装方法一: pip直接安装[安装了pip的前提下] omc@omc-virtual-machine: ...
- Celery定时任务|计划任务
适用场景几点几分执行特定的任务 定时任务 配置这个无需多说了和上篇文章一样 任务函数 硬菜来了 添加任务时候的写法 第一种: from celery_task.order_task import or ...
- Flask、Celery、RabbitMQ学习计划
Flask (9.16-9.23) 相关组件了解 (9.16-17) WSGI:Werkzeug 数据库:SQLAlchemy *重点查看 urls和视图 (9.18-19) session和co ...
随机推荐
- div style标签内嵌CSS样式
我们在DIV标签内.SPAN标签内.p标签等html标签内使用style属性直接设置div的样式. 一.在<div>标签内使用style设置css样式 - TOP 1.实例html ...
- python基础--类的继承以及mro
继承: 什么是继承: 继承是一种关系,描述两个对象之间什么是什么的关系 在程序中,继承描述的是类和类之间的关系 例如 a继承了b,a就能直接使用b已经存在的方法和属性了 a称之为子类,b称之为父类,成 ...
- php的FTP操作类
class_ftp.php <?php /** * 作用:FTP操作类( 拷贝.移动.删除文件/创建目录 ) */ class class_ftp { public $off; // 返回操作状 ...
- 【模板】Tarjan缩点,强连通分量 洛谷P2341 [HAOI2006]受欢迎的牛 [2017年6月计划 强连通分量01]
P2341 [HAOI2006]受欢迎的牛 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的“喜欢”是可以传递的 ...
- 【CRT相关配置】
1.选项——会话选项 2.回话调整如下: 3.日志文件记录保存,即保存所有输入的命令 文件名:%S-%T-%M-%D.txt,表示每天会存放到一个文件 选择:在连接上启动记录 和 追加到文件
- bzoj2049: [Sdoi2008]Cave 洞穴探测
bzoj2049: [Sdoi2008]Cave 洞穴探测 给n个点,每次连接两个点或切断一条边,保证是树结构,多次询问两个点是否联通 Lct裸题 //Achen #include<algori ...
- DOM 创建元素 删除元素(结点)
创建新的 HTML 元素 如需向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素. <script> var para=document. ...
- css中用一张背景图做页面的技术有什么优势?
css中用一张背景图做页面的技术有什么优势? 简单介绍一下 CSS Sprites 的优点: 当用户往U盘中拷200张图片,会等很久.但是如果弄成一个文件,再拷贝就会快很多. CSS Sprites ...
- Codeforces Round #197 (Div. 2) A. Helpful Maths【字符串/给一个连加计算式,只包含数字 1、2、3,要求重新排序,使得连加的数字从小到大】
A. Helpful Maths time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...
- tomcat的日志不输出日志信息的解决方法
1.下载日志jar包,例如:commons-logging-1.1.1.jar.放在tomcat的bin目录下,或者是自己项目的lib包里. 2.修改tomcat的bin目录下面的catalina.b ...
