mirror of https://github.com/mitsuhiko/flask.git
72 lines
2.8 KiB
72 lines
2.8 KiB
.. _deploying-uwsgi: |
|
|
|
uWSGI |
|
===== |
|
|
|
uWSGI is a deployment option on servers like `nginx`_, `lighttpd`_, and |
|
`cherokee`_; see :ref:`deploying-fastcgi` and :ref:`deploying-wsgi-standalone` |
|
for other options. To use your WSGI application with uWSGI protocol you will |
|
need a uWSGI server first. uWSGI is both a protocol and an application server; |
|
the application server can serve uWSGI, FastCGI, and HTTP protocols. |
|
|
|
The most popular uWSGI server is `uwsgi`_, which we will use for this |
|
guide. Make sure to have it installed to follow along. |
|
|
|
.. admonition:: Watch Out |
|
|
|
Please make sure in advance that any ``app.run()`` calls you might |
|
have in your application file are inside an ``if __name__ == |
|
'__main__':`` block or moved to a separate file. Just make sure it's |
|
not called because this will always start a local WSGI server which |
|
we do not want if we deploy that application to uWSGI. |
|
|
|
Starting your app with uwsgi |
|
---------------------------- |
|
|
|
`uwsgi` is designed to operate on WSGI callables found in python modules. |
|
|
|
Given a flask application in myapp.py, use the following command: |
|
|
|
.. sourcecode:: text |
|
|
|
$ uwsgi -s /tmp/uwsgi.sock --manage-script-name --mount /yourapplication=myapp:app |
|
|
|
The ``--manage-script-name`` will move the handling of ``SCRIPT_NAME`` to uwsgi, |
|
since its smarter about that. It is used together with the ``--mount`` directive |
|
which will make requests to ``/yourapplication`` be directed to ``myapp:app``. |
|
If your application is accessible at root level, you can use a single ``/`` |
|
instead of ``/yourapplication``. ``myapp`` refers to the name of the file of |
|
your flask application (without extension) or the module which provides ``app``. |
|
``app`` is the callable inside of your application (usually the line reads |
|
``app = Flask(__name__)``. |
|
|
|
If you want to deploy your flask application inside of a virtual environment, |
|
you need to also add ``--virtualenv /path/to/virtual/environment``. You might |
|
also need to add ``--plugin python`` or ``--plugin python3`` depending on which |
|
python version you use for your project. |
|
|
|
Configuring nginx |
|
----------------- |
|
|
|
A basic flask nginx configuration looks like this:: |
|
|
|
location = /yourapplication { rewrite ^ /yourapplication/; } |
|
location /yourapplication { try_files $uri @yourapplication; } |
|
location @yourapplication { |
|
include uwsgi_params; |
|
uwsgi_pass unix:/tmp/yourapplication.sock; |
|
} |
|
|
|
This configuration binds the application to ``/yourapplication``. If you want |
|
to have it in the URL root its a bit simpler:: |
|
|
|
location / { try_files $uri @yourapplication; } |
|
location @yourapplication { |
|
include uwsgi_params; |
|
uwsgi_pass unix:/tmp/yourapplication.sock; |
|
} |
|
|
|
.. _nginx: http://nginx.org/ |
|
.. _lighttpd: http://www.lighttpd.net/ |
|
.. _cherokee: http://cherokee-project.com/ |
|
.. _uwsgi: http://projects.unbit.it/uwsgi/
|
|
|