1
0
mirror of https://github.com/django/django.git synced 2025-01-15 21:02:52 +00:00

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

43 lines
1.5 KiB
Plaintext
Raw Normal View History

====================
How to deploy Django
====================
Django is full of shortcuts to make web developers' lives easier, but all
those tools are of no use if you can't easily deploy your sites. Since Django's
inception, ease of deployment has been a major goal.
There are many options for deploying your Django application, based on your
architecture or your particular business needs, but that discussion is outside
the scope of what Django can give you as guidance.
Django, being a web framework, needs a web server in order to operate. And
since most web servers don't natively speak Python, we need an interface to
make that communication happen.
Django currently supports two interfaces: WSGI and ASGI.
* `WSGI`_ is the main Python standard for communicating between web servers and
applications, but it only supports synchronous code.
* `ASGI`_ is the new, asynchronous-friendly standard that will allow your
Django site to use asynchronous Python features, and asynchronous Django
features as they are developed.
You should also consider how you will handle :doc:`static files
</howto/static-files/deployment>` for your application, and how to handle
:doc:`error reporting</howto/error-reporting>`.
Finally, before you deploy your application to production, you should run
through our :doc:`deployment checklist<checklist>` to ensure that your
configurations are suitable.
.. _WSGI: https://wsgi.readthedocs.io/en/latest/
.. _ASGI: https://asgi.readthedocs.io/en/latest/
.. toctree::
:maxdepth: 2
wsgi/index
asgi/index
checklist