Flask 开发服务器中的双重重启打印输出
使用 Flask 运行网站开发服务器时,用户注意到服务器重启的异常行为消息出现两次而不是一次。为了理解这背后的原因,让我们深入研究 Flask 开发服务器的机制。
Flask 利用 Werkzeug(一个 WSGI 实用程序库)通过 app.run() 方法启动开发服务器。 Werkzeug 采用一种称为“重新加载”的技术,在检测到代码更改后自动重新启动服务器。重新加载过程涉及生成一个子进程,该子进程使用 subprocess.call() 再次运行 Flask 脚本。
该子进程假定与父进程具有相同的代码,导致重新启动消息的双重执行。要消除此行为,请将 app.run() 的 use_reloader 参数设置为 False。或者,在 Flask 的命令行执行期间禁用重新加载器:
FLASK_DEBUG=1 flask run --no-reload
对于检测是否存在重新加载子进程至关重要的高级场景,请使用 Werkzeug 的 is_running_from_reloader() 函数。但是,建议使用 @app.before_first_request 装饰器来初始化模块全局变量,保证每次重新加载后一次执行。
@app.before_first_request def before_first_request(): print(f"########### Restarted, first request @ {datetime.utcnow()} ############")
请注意,在完整的 WSGI 中,可能会为每个新子进程调用 before_first_request 处理程序使用分叉或新子进程的服务器。
以上是为什么我的 Flask 开发服务器显示双重重启消息?的详细内容。更多信息请关注PHP中文网其他相关文章!