首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >工作队列设计模式?

工作队列设计模式?
EN

Stack Overflow用户
提问于 2019-12-05 12:55:34
回答 1查看 279关注 0票数 1

假设我有一个简单的代价高昂的函数,它将一些结果存储到一个文件中:

代码语言:javascript
复制
def costly_function(filename):
    time.sleep(10)
    with open('filename', 'w') as f:
        f.write("I am done!)

现在,假设我想在dask中安排一些这些任务,然后这些任务异步地接收这些请求,然后一个一个地运行这些函数。我现在正在设置一个dask客户对象..。

代码语言:javascript
复制
cluster = dask.distributed.LocalCluster(n_workers=1, processes=False)  # my attempt at sequential job processing
client = dask.distributed.Client(cluster)

..。然后交互地(从IPython)调度这些作业:

代码语言:javascript
复制
>>> client.schedule(costly_function, "result1.txt")
>>> client.schedule(costly_function, "result2.txt")
>>> client.schedule(costly_function, "result3.txt")

我遇到的问题是,这些任务不是连续运行的,而是以parralel方式运行的,在我的特殊情况下,这会导致并发问题。

因此,我的问题是:像我在dask中描述的那样,建立作业队列的正确方法是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-05 13:58:40

好的,我想我可能有一个解决方案(尽管可以想出更好的解决方案)。它需要稍微修改以前昂贵的功能:

代码语言:javascript
复制
def costly_function(filename, prev_job=None):
    time.sleep(10)
    with open('filename', 'w') as f:
        f.write("I am done!")

cluster = dask.distributed.LocalCluster(n_workers=1, processes=False)  # my attempt at sequential job processing
client = dask.distributed.Client(cluster)

然后,在交互式上下文中,您将编写以下内容:

代码语言:javascript
复制
>>> future = client.submit(costly_function, "result1.txt")
>>> future = client.submit(costly_function, "result2.txt", prev_job=future)
>>> future = client.submit(costly_function, "result3.txt", prev_job=future)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59195701

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档