0

在阅读了关于基于文件目标的输出缓存 的文档后,我认为这个工作流应该是输出缓存的一个示例:

from time import sleep
from prefect import Flow, task
from prefect.engine.results import LocalResult


@task(target="func_task_target.txt", checkpoint=True, 
      result=LocalResult(dir="~/.prefect"))
def func_task():
    sleep(5)
    return 99

with Flow("Test-cache") as flow:
    func_task()

if __name__ == '__main__':
    flow.run()

我希望func_task运行一次,得到缓存,然后在下次运行流程时使用缓存的值。但是,似乎func_task每次都运行。

我哪里错了?还是我误解了文档?

4

1 回答 1

4

尝试将环境变量设置PREFECT__FLOWS__CHECKPOINTINGTrue

import os
os.environ["PREFECT__FLOWS__CHECKPOINTING"] = "true"

您还可以更改结果目录

os.environ["PREFECT__HOME_DIR"] = "path to dir"
于 2021-06-09T14:09:27.783 回答