[英]Flask multiprocessing does not return the response until a process is finished
我有一个带有代码块的烧瓶应用程序:
if flag1 and flag2 and flag3:
logger.info("Creating new process")
p = Process(
target=some_function,
args=(
param1,
param2,
param3,
param4,
param5
),
daemon=False
)
p.start()
logger.info("Return Now")
return "OK", 200
现在, some_function 需要一段时间才能完成,我想在客户端继续工作时将响应返回给客户端。
我到了记录“立即返回”的地步,但它似乎还没有返回。 似乎在发送响应之前等待进程完成。
我不是linux或python和flask方面的专家,但是当我使用普通的flask run或python -m app命令在Windows机器上测试它时它可以工作。
作为附加信息,我将它部署在带有 uwsgi 的 linux 服务器中,并使用以下命令执行:
uwsgi --socket 127.0.0.1:9003 -w wsgi:app
为什么会这样?
提前致谢。
编辑:我也试过将 daemon 设置为 True 但结果仍然相同。 Python 版本是 3.6
编辑:应用程序的进程由 supervisord 处理,它由 uwsgi 执行,并在 nginx 后面,如果有帮助,它会通过 uwsgi_pass 传递。
编辑:我想我可能想补充一下,我认为这可能与 Nginx 相关。 正如评论中所指出的,这极不可能是烧瓶应用程序。 现在最重要的是 Nginx。
我试图解决的真正问题是:我正在向 AWS API Gateway 发送一个请求,它触发一个 Lambda 函数,然后向 Nginx 后面的 Linux 服务器中的 API 发出请求。 烧瓶应用程序工作正常,除非它产生进程时,控件似乎没有返回。 当我在 Lambda、Postman 或 Python 脚本中调用 API 时会发生这种情况。
我认为您要做的是分离您正在创建的流程 - 在这种情况下,我建议您尝试使用此答案中的双叉方法。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.