文章详情页
python - celery工作流的问题
浏览:28日期:2022-09-12 10:43:10
问题描述
celery中,我做这样的处理:一个url经过a, b, c三个的函数,分别获得返回值,其中任意函数结果均与任意其他函数结果不相关,然后汇总起来,交给之后的流程.这样,我自然想到并行运行三个函数来加快处理速度.然而由于一开始的设计问题, a函数式被设计成了一次可以处理多个url的形式,而一个一个的处理会非常慢.
@celery.taskdef a(url_list): ’...do something...’ for url in url_list:b.delay(url)
我尝试这样控制,然而任务似乎并不能嵌套.那么,如何设计可以比较好的满足我这种比较奇怪的流程和要求呢?
问题解答
回答1:应该把a;b;c拆开,写成3个task, 同时数据库里要保存一个状态值,用来表示3个任务的执行状态,一个任务执行完成后,就修改状态值,并检查其他2个任务是否完成,如果都完成了,就汇总任务结果,再处理。
回答2:@xiaoboost 手工维护状态可行,但有点费事。
Celery 是可以设计执行流程的,参考文档:Designing Work-flows题主的需求可以用 chords 搞定,在 celery task 里返回值就行。
BTW: 注意一下 Celery 配置中与返回值相关的几个选项,比如这个 task_ignore_result
相关文章:
1. font-family - 我引入CSS3自定义字体没有效果?2. 微信chooseImage接口部分机型选择图片后莫名其妙的跳转其他页面3. c++ - win764位环境下,我用GCC为什么指针占8个字节,而long是4个字节?4. css3 - 微信前端页面遇到的transition过渡动画的bug5. css - 百度Ueditor富文本编辑器初始化赋值font-size没有值?6. 用工具实现在微信里面生成带二维码的海报?7. html - 谁能推荐一个类似apple官网的模板,用来展示产品的?8. HTML5禁止img预览该怎么解决?9. 找一个权威、实战的微信扫码授权登录网站的开发教程或者文章10. ueditor上传服务器提示后端配置项没有正常加载,求助!!!!!
排行榜