- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我现在有大量文档要处理,我正在使用 Python RQ 来并行处理任务。
我希望在每个文档上执行不同的操作时完成一系列工作。例如:A
-> B
-> C
表示将文档传递给函数A
,在之后A
已完成,继续执行 B
和最后的 C
。
但是,Python RQ 似乎不能很好地支持管道内容。
这是一个简单但有点肮脏的做法。总之,管道中的每个函数都以嵌套的方式调用它的下一个函数。
例如,对于管道A
->B
->C
。
在顶层,一些代码是这样写的:
q.enqueue(A, the_doc)
其中 q 是 Queue
实例,在函数 A
中有如下代码:
q.enqueue(B, the_doc)
而在B
中,有这样的东西:
q.enqueue(C, the_doc)
还有比这更优雅的方式吗?例如 ONE 函数中的一些代码:
q.enqueue(A, the_doc)
q.enqueue(B, the_doc, after = A)
q.enqueue(C, the_doc, after= B)
depends_on参数最接近我的要求,但是,运行如下:
A_job = q.enqueue(A, the_doc)
q.enqueue(B, depends_on=A_job)
不会工作。因为 q.enqueue(B, depends_on=A_job )
在 A_job = q.enqueue(A, the_doc)
执行后立即执行。当 B 入队时,A 的结果可能还没有准备好,因为它需要时间来处理。
附言:
如果 Python RQ 不太擅长这个,我还可以使用 Python 中的什么工具来实现相同的目的:
最佳答案
By the time B is enqueued, the result from A might not be ready as it takes time to process.
我不确定您最初发布问题时是否确实如此,但无论如何,现在情况并非如此。事实上,depends_on
功能正是为您描述的工作流程而设计的。
确实这两个函数是立即连续执行的。
A_job = q.enqueue(A, the_doc)
B_job = q.enqueue(B, depends_on=A_job )
但是在 A
完成之前,worker 不会执行 B
。直到 A_job
成功执行,B.status == 'deferred'
。一旦 A.status == 'finished'
,B
就会开始运行。
这意味着 B
和 C
可以像这样访问和操作它们的依赖项的结果:
import time
from rq import Queue, get_current_job
from redis import StrictRedis
conn = StrictRedis()
q = Queue('high', connection=conn)
def A():
time.sleep(100)
return 'result A'
def B():
time.sleep(100)
current_job = get_current_job(conn)
a_job_id = current_job.dependencies[0].id
a_job_result = q.fetch_job(a_job_id).result
assert a_job_result == 'result A'
return a_job_result + ' result B'
def C():
time.sleep(100)
current_job = get_current_job(conn)
b_job_id = current_job.dependencies[0].id
b_job_result = q.fetch_job(b_job_id).result
assert b_job_result == 'result A result B'
return b_job_result + ' result C'
worker最终会打印'result A result B result C'
。
此外,如果您在队列中有很多作业并且 B
可能在执行之前等待一段时间,您可能需要显着增加 result_ttl
或使其无限期result_ttl=-1
。否则,无论为 result_ttl
设置多少秒后,A 的结果都将被清除,在这种情况下,B
将无法再访问它并返回所需的结果。
但是,设置 result_ttl=-1
具有重要的内存含义。这意味着您的作业结果将永远不会被自动清除,并且内存将按比例增长,直到您手动从 Redis 中删除这些结果。
关于 python RQ : pattern for callback,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24295090/
在我的上一个项目中,我使用了 rxJava,我意识到 observable.doOnError('onErrorCallback').subscribe(action) 和 observable.su
我是一名 C++ 初学者,我认为要真正学习指针和引用,我应该尝试创建一个回调函数,这是我在 JavaScript 中认为理所当然的事情。 但是,对于我的一生,我不知道为什么这些括号在 (*callba
我在库中有一个类,它具有在事件发生时执行的“onMessage”方法。 OnMessage 在执行时需要调用属于主应用程序中的类的“回调”方法。我假设这将通过构造函数完成,但我不知道它是如何实现的。
两者的 jQuery 文档基本上说明了相同的事情,所以我想知道两者之间是否有任何重大差异(如果有的话)。谢谢! 最佳答案 这方面的文档实际上非常糟糕,所以这是我在 studying the sourc
这个问题在这里已经有了答案: Using &&'s short-circuiting as an if statement? (6 个答案) Omitting the second expressi
我正在尝试在 golang 中定义一个回调: package main func main() { x, y := "old x ", "old y" callback
我有一个页面,其中包含从 Google 电子表格生成的许多图表。 典型代码如下所示: var url = "http://my.googlespreadsheet.com/tq?argumentshe
当我运行 linter 时,它显示: subscribe is deprecated: Use an observer instead of an error callback 代码来自 this a
对于异步套接字 // accept ... listener.BeginAccept( new AsyncCallback(AcceptCallback), listener); // listene
我希望能够根据在前面的函数中调用的是 callback(true) 还是 callback(false) 在回调函数中执行一些逻辑。 示例: foo.doFunction = function (pa
从 jQuery.scrollTo.js 库中看到这个 block (在 v1.4 的第 184 行)。 function animate( callback ){ $elem.animate
我正在尝试在我的应用中使用一些回调,它与 "callback(value)" 和 "callback.invoke(value)" 一起工作正确调用回调。 我想知道“回调(值)”是否只是一个缩短版本,
我决定从 keras 切换到 tf.keras(建议使用 here)。因此我安装了 tf.__version__=2.0.0和 tf.keras.__version__=2.2.4-tf .在我的旧版
我认为这实际上可能会回答我关于 Stack Overflow 的另一个问题如果我能确认这一点。 返回回调和只调用回调有什么区别? 我看到代码执行其中之一/或/两者,并试图思考为什么以及何时执行哪个。
我目前正在学习 Rust 并希望用它来开发 GUI基于 GTK+ 的应用程序。我的问题与注册回调有关在这些回调中响应 GTK 事件/信号和变异状态。我有一个有效但不优雅的解决方案,所以我想问一下是否有
我在回调函数中传递参数时遇到问题。我使用 redux-form,当我更改 SkinList 中的选择时,它会触发 onChange 回调 - activeSkinChange 方法 在activeSk
我有 8 个相互依赖的回调。我的想法是要有一个更具可读性的过程,但我不明白如何处理这个问题。 我的回调 hell 的一个例子是: return new Promise(function (resolv
因此,我的函数接受一个值和任意数量的回调作为参数(我应该使用扩散操作符吗?)该函数应该返回通过所有给定回调传递该值的最终结果。。我返回的“CB2(Res1)”不是一个函数。如何将第一个回调的结果传递给
在谈到 future 和回调时,documentation说是 The Vert.x core APIs are based on callbacks to notify of asynchronou
我开始觉得自己很蠢。我正在关注 Facebook-Connect 演示“The Run Around”。 当我导航到 http://www.[mysite].com/testing/register_
我是一名优秀的程序员,十分优秀!