首页 >后端开发 >Python教程 >为什么我的 Flask 开发服务器打印启动消息两次?

为什么我的 Flask 开发服务器打印启动消息两次?

Barbara Streisand
Barbara Streisand原创
2024-12-20 01:04:08329浏览

Why Does My Flask Development Server Print Startup Messages Twice?

Flask 开发服务器运行两次

使用 app.run() 方法运行 Flask 应用时,可能会遇到打印语句指示服务器重新启动的情况出现两次。此行为可归因于 Werkzeug 重新加载器。

Werkzeug 是为 Flask 开发服务器提供支持的底层库,它采用子进程机制来促进代码更改和自动重新启动。当您运行 app.run() 时,重新加载器会生成一个持续监视您的代码的子进程。

为了说明这一点,让我们剖析 Werkzeug 中的 restart_with_reloader() 函数。该函数调用 subprocess.call() 再次执行脚本,从而生成子进程。因此,您会观察 print 语句两次。

要消除这种重复,请考虑禁用重新加载器。您可以通过在 app.run() 中将 use_reloader 设置为 False 来实现此目的:

app.run(port=4004, debug=config.DEBUG, host='0.0.0.0', use_reloader=False)

或者,您可以在使用 Flask run 命令时禁用重新加载器:

FLASK_DEBUG=1 flask run --no-reload

另一个选项是利用 werkzeug.serving.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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn