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

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

Barbara Streisand
发布: 2024-12-20 01:04:08
原创
298 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板