0

0

PythonCelery任务队列实战教程_链式任务与异步执行

舞姬之光

舞姬之光

发布时间:2026-01-05 16:40:03

|

935人浏览过

|

来源于php中文网

原创

链式任务(chord)是Celery中先并发执行group内所有子任务、待全部成功后再触发callback任务的任务组合方式;其核心为chord(group, callback),依赖结果后端收集结果,callback接收按group顺序排列的结果列表。

pythoncelery任务队列实战教程_链式任务与异步执行

什么是链式任务(chord)

链式任务是 Celery 中一种特殊的任务组合方式,它把一组并行执行的子任务(group)和一个在所有子任务完成后才触发的回调任务(callback)串起来。你可以把它理解成“先并发跑一批任务,等它们全干完了,再统一处理结果”。

比如:要批量下载 100 个网页,下载完后统计总字数。下载动作可以并行,但统计必须等全部下载完成才能开始——这就适合用 chord。

怎么写一个 chord 链

核心写法很简单,用 chord(group, callback)

  • group 是一个任务列表,每个任务会被并发执行,返回各自的结果
  • callback 是单个任务,接收一个参数:包含所有 group 任务返回值的列表

示例代码:

立即学习Python免费学习笔记(深入)”;

from celery import Celery
<p>app = Celery('tasks', broker='redis://localhost:6379')</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/1351" title="云从科技AI开放平台"><img
                                                                                src="https://img.php.cn/upload/ai_manual/001/431/639/68b6d5e4278fa465.png" alt="云从科技AI开放平台"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/1351" title="云从科技AI开放平台">云从科技AI开放平台</a>
                                                                        <p>云从AI开放平台</p>
                                                                </div>
                                                                <a href="/ai/1351" title="云从科技AI开放平台" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div><p>@app.task
def add(x, y):
return x + y</p><p>@app.task
def summarize(results):
return sum(results)</p><h1>构建 chord:并发执行三个 add,完成后调用 summarize</h1><p>result = chord(
[add.s(1, 2), add.s(3, 4), add.s(5, 6)],
summarize.s()
).apply_async()</p><p>print(result.get())  # 输出 21(即 3+7+11)

注意:.s() 表示创建签名(signature),它是可序列化的任务“蓝图”,不立即执行。

异步执行的关键细节

Chord 的整个流程是完全异步的,但背后有隐含依赖逻辑:

  • group 内部任务由 Celery worker 并发拉取执行,彼此无序、无依赖
  • Celery 自动监控 group 所有任务状态,当全部成功时,才把结果打包发给 callback 任务
  • callback 任务本身也进队列,由某个 worker 拉取执行,不是主线程直接调用
  • 如果 group 中任一任务失败,默认整个 chord 失败(除非配置了 red">chord_unlock 或自定义错误处理)

生产中建议为 callback 加上重试机制:

@app.task(bind=True, autoretry_for=(Exception,), retry_kwargs={'max_retries': 3})
def summarize(self, results):
    return sum(results)

常见问题与避坑提醒

实际用 chord 容易踩几个坑:

  • 不要在 callback 里做耗时同步操作:比如发邮件、写大文件,应再转成新任务异步处理,避免阻塞 chord 调度器
  • group 太大时慎用:Celery 默认用 Redis 做结果后端时,chord 会把所有结果暂存在一个 key 里。几千个任务的结果可能撑爆内存或超 Redis 单 key 限制
  • 结果后端必须启用:chord 依赖结果后端(如 Redis、RabbitMQ、Database)来收集 group 结果。没配 result_backend?chord 会卡住不动
  • callback 接收的是 list,不是 dict:顺序和 group 中任务顺序一致,不是按任务 ID 或返回时间排序

需要更灵活的聚合逻辑?可以改用 group + callback 手动触发,或者用 canvas 中的 chords 结合 apply_chunks 分批处理。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

207

2024.02.23

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

49

2026.01.28

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

550

2023.10.23

discuz database error怎么解决
discuz database error怎么解决

discuz database error的解决办法有:1、检查数据库配置;2、确保数据库服务器正在运行;3、检查数据库表状态;4、备份数据;5、清理缓存;6、重新安装Discuz;7、检查服务器资源;8、联系Discuz官方支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2023.11.20

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1007

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

671

2023.11.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

1

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号