Flask 应用程序中的多进程旋转 2 个进程
Multiprocess within flask app spinning up 2 processes
我正在构建一个 Flask 应用程序,需要一些后台进程才能 运行。我决定使用多进程,但在 Flask 中 运行ning 时它会产生两个进程。有谁知道为什么会这样?我在 OS X 和 Ubuntu 12.04 上测试过,结果相同。这是一个例子:
import time
import multiprocessing
from flask import Flask
app = Flask(__name__)
backProc = None
def testFun():
print('Starting')
while True:
time.sleep(3)
print('looping')
time.sleep(3)
print('3 Seconds Later')
@app.route('/')
def root():
return 'Started a background process with PID ' + str(backProc.pid) + " is running: " + str(backProc.is_alive())
@app.route('/kill')
def kill():
backProc.terminate()
return 'killed: ' + str(backProc.pid)
@app.route('/kill_all')
def kill_all():
proc = multiprocessing.active_children()
for p in proc:
p.terminate()
return 'killed all'
@app.route('/active')
def active():
proc = multiprocessing.active_children()
arr = []
for p in proc:
print(p.pid)
arr.append(p.pid)
return str(arr)
@app.route('/start')
def start():
global backProc
backProc = multiprocessing.Process(target=testFun, args=(), daemon=True)
backProc.start()
return 'started: ' + str(backProc.pid)
if __name__ == '__main__':
app.run(port=int("7879"))
这是 Flask auto-reload 功能的问题,该功能在开发期间用于在检测到代码更改时自动重启网络服务器,以便在无需手动重启的情况下提供新代码。
在指南中,“app.run()”
调用始终置于 “if __name__ == ‘__main__’”
条件内,因为重新加载器默认设置为打开。使用多处理时,此条件将导致 false,因此在如下函数中使用 Flask 自动重载时必须禁用它:
def startWebserver():
app.run(debug=True, use_reloader=False)
Link供参考:
http://blog.davidvassallo.me/2013/10/23/nugget-post-python-flask-framework-and-multiprocessing/
我正在构建一个 Flask 应用程序,需要一些后台进程才能 运行。我决定使用多进程,但在 Flask 中 运行ning 时它会产生两个进程。有谁知道为什么会这样?我在 OS X 和 Ubuntu 12.04 上测试过,结果相同。这是一个例子:
import time
import multiprocessing
from flask import Flask
app = Flask(__name__)
backProc = None
def testFun():
print('Starting')
while True:
time.sleep(3)
print('looping')
time.sleep(3)
print('3 Seconds Later')
@app.route('/')
def root():
return 'Started a background process with PID ' + str(backProc.pid) + " is running: " + str(backProc.is_alive())
@app.route('/kill')
def kill():
backProc.terminate()
return 'killed: ' + str(backProc.pid)
@app.route('/kill_all')
def kill_all():
proc = multiprocessing.active_children()
for p in proc:
p.terminate()
return 'killed all'
@app.route('/active')
def active():
proc = multiprocessing.active_children()
arr = []
for p in proc:
print(p.pid)
arr.append(p.pid)
return str(arr)
@app.route('/start')
def start():
global backProc
backProc = multiprocessing.Process(target=testFun, args=(), daemon=True)
backProc.start()
return 'started: ' + str(backProc.pid)
if __name__ == '__main__':
app.run(port=int("7879"))
这是 Flask auto-reload 功能的问题,该功能在开发期间用于在检测到代码更改时自动重启网络服务器,以便在无需手动重启的情况下提供新代码。
在指南中,“app.run()”
调用始终置于 “if __name__ == ‘__main__’”
条件内,因为重新加载器默认设置为打开。使用多处理时,此条件将导致 false,因此在如下函数中使用 Flask 自动重载时必须禁用它:
def startWebserver():
app.run(debug=True, use_reloader=False)
Link供参考:
http://blog.davidvassallo.me/2013/10/23/nugget-post-python-flask-framework-and-multiprocessing/