Home >Backend Development >Python Tutorial >Why Does My Flask Development Server Print Startup Messages Twice?

Why Does My Flask Development Server Print Startup Messages Twice?

Barbara Streisand
Barbara StreisandOriginal
2024-12-20 01:04:08301browse

Why Does My Flask Development Server Print Startup Messages Twice?

Flask Development Server Running Twice

When running a Flask application using the app.run() method, you may encounter a situation where the print statement indicating the server restart appears twice. This behavior can be attributed to the Werkzeug reloader.

Werkzeug, the underlying library powering Flask's development server, employs a child process mechanism to facilitate code changes and auto-restarting. When you run app.run(), the reloader spawns a child process that consistently monitors your code.

To illustrate this, let's dissect the restart_with_reloader() function in Werkzeug. The function calls subprocess.call() to execute your script again, leading to the spawning of a child process. Consequently, you observe the print statement twice.

To eliminate this duplication, consider disabling the reloader. You can achieve this by setting use_reloader to False in app.run():

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

Alternatively, you can disable the reloader when using the flask run command:

FLASK_DEBUG=1 flask run --no-reload

Another option is to utilize the werkzeug.serving.is_running_from_reloader() function to determine if you're executing within the reloader's child process.

However, if you require module globals, opt for the @app.before_first_request decorator. This decorator lets you specify a function that will be invoked once after each reload, when the first request is received:

@app.before_first_request
def before_first_request():
    print(f"########### Restarted, first request @ {datetime.utcnow()} ############")

Note that when running in a full-scale WSGI server employing forking or subprocesses for request handling, before_first_request handlers might be invoked for each newly created subprocess.

The above is the detailed content of Why Does My Flask Development Server Print Startup Messages Twice?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn