Healtchecks for Django
Project description
django-alive 🕺
Provides two healthcheck endpoints for your Django application:
Alive
Verifies the WSGI server is responding.
- Default URL:
/-/alive/ - Success:
- status code:
200 - content:
ok
- status code:
- Failure: This view never returns a failure. A failure would mean your WSGI server is not running.
Health
Verifies services are ready.
- Default URL:
/-/health/ - Success:
- status_code:
200 - content:
{"healthy": true}
- status_code:
- Failure:
- status_code:
503 - content:
{"healthy": false, "errors": ["error 1", "error 2"]}
- status_code:
By default the health endpoint will test the database connection, but can be configured to check the cache, staticfiles, or any additional custom checks.
Supports Django 3.2+ on Python 3.6+.
Install
pip install django-alive
Configure
Add this to your project's urlpatterns:
path("-/", include("django_alive.urls"))
If you wish to use the healthcheck management command, add
django_alive to the INSTALLED_APPS.
Enabling Checks
The default "health" endpoint will test a simple SELECT 1 query on the database. Additional checks can be enabled in your Django settings.
Use the ALIVE_CHECKS setting to configure the checks to include. It is a list of tuples with the path to a Python function as a first argiment and dict of keyword arguments to pass to that function as a second argument. A full example:
ALIVE_CHECKS = [
("django_alive.checks.check_database", {}),
("django_alive.checks.check_staticfile", {
"filename": "img/favicon.ico",
}),
("django_alive.checks.check_cache", {
"cache": "session",
"key": "test123",
}),
("django_alive.checks.check_migrations", {}),
]
⚠️ Warning: Changed in version 1.3.0 ⚠️
NOTE: Old settings with ALIVE_CHECKS as dict was deprecated in favor of a list of tuples.
Built-in Checks
Defined in django_alive.checks.
def check_cache(key="django-alive", cache="default")
Fetch a cache key against the specified cache.
Parameters:
key(str): Cache key to fetch (does not need to exist)cache(str): Cache alias to execute against
def check_database(query="SELECT 1", database="default")
Run a SQL query against the specified database.
Parameters:
query(str): SQL to executedatabase(str): Database alias to execute against
def check_migrations(alias=None)
Verify all defined migrations have been applied
Parameters:
alias(str): An optional database alias (default: check all defined databases)
def check_staticfile(filename)
Verify a static file is reachable
Parameters:
filename(str): static file to verify
Management Command
In addition to the view, the configured healthchecks can also be run via a management command with manage.py healthcheck. This will exit with an error code if all the healthchecks do not pass.
Custom Checks
django-alive is designed to easily extend with your own custom checks. Simply define a function which performs your check and raises a django_alive.HealthcheckFailure exception in the event of a failure. See checks.py for some examples on how to write a check.
Disabling ALLOWED_HOSTS for Healthchecks
Often, load balancers will not pass a Host header when probing a healthcheck endpoint. This presents a problem for Django's host header validation. A middleware is included that will turn off the host checking only for the healthcheck endpoints. This is safe since these views never do anything with the Host header.
Enable the middleware by inserting this at the beginning of your MIDDLEWARE:
MIDDLEWARE = [
"django_alive.middleware.healthcheck_bypass_host_check",
# ...
]
Handling SECURE_SSL_REDIRECT
If your load balancer is doing HTTPS termination and you have SECURE_SSL_REDIRECT=True in your settings, you want to make sure that your healtcheck URLs are not also redirected to HTTPS. In that case, add the following to your settings:
SECURE_REDIRECT_EXEMPT = [r"^-/"] # django-alive URLs
2.0.0 (2024-08-30)
- Allow executing checks multiple times with different parameters;
ALIVE_CHECKSshould now be a list of tuples (setting it to a dictionary results in a deprecation warning).
1.2.2 (2024-08-14)
- Add GitHub Action for running tests against supported versions
- Release from GitHub Actions
1.2.1 (2021-07-23)
- Update PyPI metadata
1.2.0 (2021-07-23)
- Updated test matrix. Python 2 no longer "officially" supported.
- Prevent Traceback in middleware if URLs are not setup
1.1.0 (2019-11-06)
- Added
healthcheckmanagement command - Added optional
check_migrationshealthcheck
1.0.1 (2018-09-10)
- Documentation improvements
- Python 3.7 support
1.0.0 (2018-08-21)
- Initial release
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file django_alive-2.0.0.tar.gz.
File metadata
- Download URL: django_alive-2.0.0.tar.gz
- Upload date:
- Size: 11.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f7aa691db23b1065bdbaee96d8c347e3d9df2be783c9d5514f7fd82e9c9ee088
|
|
| MD5 |
05924b50be9438f80c8c39d514c7eb5a
|
|
| BLAKE2b-256 |
2204f57684e7b157f4d1c9327284d876da7f04197b7c34308702ec201d9429e2
|
File details
Details for the file django_alive-2.0.0-py2.py3-none-any.whl.
File metadata
- Download URL: django_alive-2.0.0-py2.py3-none-any.whl
- Upload date:
- Size: 11.8 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c8e5a767080566aefac6b05d60e4371871f292e0e32a753b6c18b8c28f473c3e
|
|
| MD5 |
a90fdd0d142361af3dbe7ab37d087f95
|
|
| BLAKE2b-256 |
7d5548839b7a01d8ad2f084b5c3a76a5acd5c7e4f3dc8d8fe7def35154a8f5c8
|