我正在构建一个烧瓶应用程序,需要一些后台进程才能运行。我决定使用multiprocess,但是在Flask中运行时它会产生两个进程。有谁知道为什么会这样?我在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"))
答案 0 :(得分:11)
Flask自动重新加载功能存在问题,在开发过程中会在检测到代码更改时自动重启Web服务器,以便在不需要手动重启的情况下提供新代码。
在指南中,“app.run()”
调用始终位于“if __name__ == ‘__main__’”
条件下,因为默认情况下重新加载器设置为开启。使用多处理时,这种情况会导致错误,所以在这样的函数中使用时,你必须禁用Flask自动重载:
def startWebserver():
app.run(debug=True, use_reloader=False)
参考链接:
http://blog.davidvassallo.me/2013/10/23/nugget-post-python-flask-framework-and-multiprocessing/