Skip to content

Latest commit

 

History

History
62 lines (45 loc) · 1.94 KB

File metadata and controls

62 lines (45 loc) · 1.94 KB

Development Server

.. currentmodule:: flask

Starting with Flask 0.11 there are multiple built-in ways to run a development server. The best one is the :command:`flask` command line utility but you can also continue using the :meth:`Flask.run` method.

Command Line

The :command:`flask` command line script (:ref:`cli`) is strongly recommended for development because it provides a superior reload experience due to how it loads the application. The basic usage is like this:

$ export FLASK_APP=my_application
$ export FLASK_ENV=development
$ flask run

This enables the development environment, including the interactive debugger and reloader, and then starts the server on http://localhost:5000/.

The individual features of the server can be controlled by passing more arguments to the run option. For instance the reloader can be disabled:

$ flask run --no-reload

Note

Prior to Flask 1.0 the :envvar:`FLASK_ENV` environment variable was not supported and you needed to enable debug mode by exporting FLASK_DEBUG=1. This can still be used to control debug mode, but you should prefer setting the development environment as shown above.

In Code

The alternative way to start the application is through the :meth:`Flask.run` method. This will immediately launch a local server exactly the same way the :command:`flask` script does.

Example:

if __name__ == '__main__':
    app.run()

This works well for the common case but it does not work well for development which is why from Flask 0.11 onwards the :command:`flask` method is recommended. The reason for this is that due to how the reload mechanism works there are some bizarre side-effects (like executing certain code twice, sometimes crashing without message or dying when a syntax or import error happens).

It is however still a perfectly valid method for invoking a non automatic reloading application.