Skip to main content

Django management commands for production webservers

Project description

django-webserver

Run production webservers such as pyuwsgi (aka uWSGI) or gunicorn as a Django management command.


build status pypi pyversions

Usage

  1. Install a variant:

    pip install django-webserver[pyuwsgi]
    

    or

    pip install django-webserver[gunicorn]
    

    or

    pip install django-webserver[uvicorn]  # Python 3.5+ only
    

    or

    pip install django-webserver[waitress]
    
  2. Add to INSTALLED_APPS:

    INSTALLED_APPS = [
       # ...
       "django_webserver",
       # ...
    ]
    
  3. Run:

    manage.py pyuwsgi --http=:8000 ...
    

    or

    manage.py gunicorn
    

    or

    manage.py uvicorn
    

    or

    manage.py waitress --port=8000
    

Configuration

With pyuwsgi

uwsgi logo

(py)uWSGI docs

Pyuwsgi already knows the Python interpreter and virtualenv (if applicable) to use from the Django management command environment. By default, it will run with the following flags (using settings.WSGI_APPLICATION to determine the module):

--strict --need-app --module={derived}

If you have STATIC_URL defined with a local URL, it will also add --static-map, derived from STATIC_URL and STATIC_ROOT.

You can pass any additional arguments uWSGI accepts in from the command line.

But uWSGI has a lot of flags, and many of them, you want every time you run the project. For that scenario, you can configure your own defaults using the optional setting, PYUWSGI_ARGS. Here's an example you might find helpful:

PYUWSGI_ARGS = [
    "--master",
    "--strict",
    "--need-app",
    "--module".
    ":".join(WSGI_APPLICATION.rsplit(".", 1)),
    "--no-orphans",
    "--vacuum",
    "--auto-procname",
    "--enable-threads",
    "--offload-threads=4",
    "--thunder-lock",
    "--static-map",
    "=".join([STATIC_URL.rstrip("/"), STATIC_ROOT]),
    "--static-expires",
    "/* 7776000",
]

Don't forget to also set something like --socket=:8000 or --http=:8000 so your app listens on a port. Depending on your setup, it may make more sense to pass this in via the command line than hard-coding it in your settings.

With gunicorn

gunicorn logo

gunicorn docs

Same as the standard gunicorn configuration, but the application will be set for you from settings.WSGI_APPLICATION.

Note: Unlike the other servers, you have to configure gunicorn with environment variables or via sys.argv. If you use it with Django's call_command, keep in mind any additional arguments you pass will not be applied.

With uvicorn

uvicorn logo

uvicorn docs

Same as the standard uvicorn configuration, but the application will be set for you from settings.WSGI_APPLICATION as well as --wsgi.

With waitress

waitress logo

waitress docs

Same as the standard waitress-serve arguments, but the application will be set for you from settings.WSGI_APPLICATION.

Unlike the other servers, waitress is supported on Windows.

Pre-warming Your App

Default:

WEBSERVER_WARMUP = True

Typically, when a WSGI server starts, it will bind to the necessary ports then import/setup your application. On larger projects, it's normal for startup to take multiple seconds. During that time, it is unable to respond to incoming requests.

To avoid that downtime, this app imports your WSGI module before starting the relevant server. If, for some reason this behavior is undesirable, you can set WEBSERVER_WARMUP = False in your settings.

Running a Healthcheck at Startup

This is not enabled by default. It requires WEBSERVER_WARMUP = True.

WEBSERVER_WARMUP_HEALTHCHECK = "/-/health/"

Internally calls the provided URL prior to starting the server and exits with a failure if it does not return a 200.

It can be helpful to have your app exit immediately if it is unable to successfully respond to a healthcheck. Your process or container manager should immediately show the service failed instead of waiting for a load balancer or some other monitoring tool to notify catch the problem.

Motivation

In some scenarios, it is beneficial to distribute a Django project with a single entrypoint for command-line interaction. This can come in handy when building Docker containers or self-contained Python apps with something like shiv.

Pre-warming the application and running a healthcheck can also open the door for some zero-downtime deployment scenarios that previously weren't possible due to the issues described in "Pre-warming your app". For example, you could use the --reuse-port option in uWSGI or gunicorn to bring up a new version of your app on the same port, knowing it is already warmed-up and healthy. After a successful startup, the old version can safely be torn down without dropping any traffic.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-webserver-1.2.0.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

django_webserver-1.2.0-py2.py3-none-any.whl (10.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-webserver-1.2.0.tar.gz.

File metadata

  • Download URL: django-webserver-1.2.0.tar.gz
  • Upload date:
  • Size: 7.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.24.0

File hashes

Hashes for django-webserver-1.2.0.tar.gz
Algorithm Hash digest
SHA256 c976979d15b5ff9a212f7904d3b779e22219aebb4857860fcaf20e4e40f1da40
MD5 2d07903a106601dc6968074436acaf7d
BLAKE2b-256 9518aeb1b12c7050cbd1edfa77467cd7c70e1125d2ff501b13893e946198b667

See more details on using hashes here.

File details

Details for the file django_webserver-1.2.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_webserver-1.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 09200631f266484b9e944e38e92681d6e9aa7d90d089a5c86d5fb08fddad84fe
MD5 d416bf7076ab9d0f94c2fbf96acedad1
BLAKE2b-256 94b7cfeba1895c5b4726e0dcf7e00c17986bd7d8f65f4f4fc8be818cf3ec5e8e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page