写了一个使用 flask 作为服务框架的程序,发现每次启动程序的时候,使用 ps
都能观察到两个 python 进程。
此外,这个程序占用了 GPU 资源,我发现有两个 python 进程,分别占用了完全相同的 GPU 显存
问题出在 flask 的启动方式上,我启动的时候,是这样启动的
app.run(debug=True, host='0.0.0.0', port=5000)
查到的资料如下,Flask 中的 debug 参数有以下主要作用:
debug=True
的特性:
debug=False
的特性:
我们看到,当 debug 为 True 的时候,会出现双进程的情况。
方案1:将 debug 设置为 False,可以结合环境变量设置线上和开发使用不同的配置
方案2:使用 os.environ.get('WERKZEUG_RUN_MAIN')
来检测执行进程,资源消耗性操作只在单独进程中执行
Werkzeug
实现的一个简单的开发服务器,线上环境中问题较多,例如性能较差、安全性不足等。老的版本还出现过并发量较大时服务被打挂无法恢复的问题。