gpt4 book ai didi

python - 等到远程服务器中的进程使用 Fabric 完成

转载 作者:太空宇宙 更新时间:2023-11-03 15:08:32 27 4
gpt4 key购买 nike

设置

我正在使用 Fabric在远程服务器上启动进程。我的本地服务器执行一个 Python 文件,该文件依次运行三个函数:本地服务器中的第一个和第三个以及远程服务器中的第二个,如下所示。

local_file.py

local_function_1()
remote_function()
local_function_2()

远程函数是在本地fabfile 中指定的函数,如下。

fabfile.py

from fabric.api import *
@hosts(remote_server)
def remote_function():
run('python function_on_remote_server.py')

问题

local_function_2 应该在 remote_function 完成运行后运行,但我不确定如何完成此操作。

我考虑过 (1) 在 local_function_2 运行之前等待固定的秒数,以及 (2) 添加一个中间本地函数来检查 remote_function 的某些输出是否存在> 在运行 local_function_2 之前。

如何将本地服务器上的函数的执行延迟到远程服务器上的函数完成运行之后?

最佳答案

一种方法是更改​​您调用 remote_function 的方式,并改用 Fabric execute

from fabric.api import execute

local_function_1()
execute(remote_function)
local_function_2()

执行应该阻塞直到任务完成。

有关详细信息,请参阅 Intelligently executing tasks with execute .

关于python - 等到远程服务器中的进程使用 Fabric 完成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29948065/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com