celery初级教程(六)
来源:互联网 发布:知世与艾利欧结婚甜文 编辑:程序博客网 时间:2024/06/06 01:17
1. signature
我们到目前为止只是学习了如何使用delay()方法,当然这个方法也是非常常用的。但是有时我们并不想简单的将任务发送到队列中,我们想将一个任务函数(由参数和执行选项组成)作为一个参数传递给另外一个函数中,为了实现此目标,Celery使用一种叫做signatures的东西。
一个signature包装了一个参数和执行选项的单个任务调用。我们可将这个signature传递给函数。
我们先看下tasks.py模块中定义的任务函数:
from proj.celery import app as celery_app# 创建任务函数@celery_app.taskdef my_task1(): print("任务函数(my_task1)正在执行....")@celery_app.taskdef my_task2(): print("任务函数(my_task2)正在执行....")@celery_app.taskdef my_task3(): print("任务函数(my_task3)正在执行....")我们将my_task1()任务包装称一个signature:
t1 = my_task1.signatures(countdown=10)t1.delay()
也可以用更简单的方式:
t1 my_task1.s(countdown=10)t1.delay()
2. Primitives
这些primitives本身就是signature对象,因此它们可以以多种方式组合成复杂的工作流程。primitives如下:
group: 一组任务并行执行,返回一组返回值,并可以按顺序检索返回值。
chain: 任务一个一个执行,一个执行完将执行return结果传递给下一个任务函数.
tasks.py模块如下:
from proj.celery import app as celery_app# 创建任务函数@celery_app.taskdef my_task1(a, b): print("任务函数(my_task1)正在执行....") return a + b@celery_app.taskdef my_task2(a, b): print("任务函数(my_task2)正在执行....") return a + b@celery_app.taskdef my_task3(a, b): print("任务函数(my_task3)正在执行....") return a + bgroup案例如下(test.py模块):
from proj.tasks import my_task1from proj.tasks import my_task2from proj.tasks import my_task3from celery import group# 将多个signature放入同一组中my_group = group((my_task1.s(10, 10), my_task2.s(20, 20), my_task3.s(30, 30)))ret = my_group() # 执行组任务print(ret.get()) # 输出每个任务结果
chain案例如下(test.py模块):
from proj.tasks import my_task1from proj.tasks import my_task2from proj.tasks import my_task3from celery import chain# 将多个signature组成一个任务链# my_task1的运行结果将会传递给my_task2# my_task2的运行结果会传递给my_task3my_chain = chain(my_task1.s(10, 10) | my_task2.s(20) | my_task3.s(30))ret = my_chain() # 执行任务链print(ret.get()) # 输出最终结果
阅读全文
0 0
- celery初级教程(六)
- celery初级教程(一)
- celery初级教程(二)
- celery初级教程(三)
- celery初级教程(四)
- celery初级教程(五)
- celery初级教程(七)
- Celery
- celery
- celery
- Celery
- 初级教程
- [Celery]Celery 最佳实践
- 【cocos2d-x 初级教程之六 2.x版本】cocos2d-x如何播放音乐和音效
- celery 简介
- celery入门
- 使用Celery
- Celery实践
- 九九乘法表
- 拓扑排序(Topological Sorting)
- Anaconda 安装、配置、基本使用
- ehcache的使用
- vue 事件绑定 处理-
- celery初级教程(六)
- 重新认识递归
- 杭电OJ——1198 Farm Irrigation (搜索)
- 无法ping通阿里云ECS服务器公网地址解决
- 浅谈Maven中的POM.XML
- BZOJ 3262: 陌上花开(CDQ分治)
- My-第一个程序
- 2018北邮计算机、网研、网安803考研报考建议
- 使用Sqoop导入导出关系型数据库数据