Skip to main content

Application that provides an API to check the status of some parts and some utilities like ping.

Project description

Version:
2.2.1
Status:
Production/Stable
Author:

José Antonio Perdiguero López

Django Status is an application that provides an API to check the status of some parts and some utilities like ping requests. This application can works as standalone or included in a Django project.

Quick start

  1. Install this package using pip:

    pip install django-status
  2. Add PROJECT_PATH to your django settings module.

  3. Add status to your INSTALLED_APPS settings like this:

    INSTALLED_APPS = (
        ...
        'status',
    )
  4. Add Django-status urls to your project urls:

    urlpatterns = [
        ...
        url(r'^status/', include('status.urls')),
    ]

Check Providers

Django Status provides a mechanism to add new custom check functions through check providers. Each check provider will generate a new API method with an URL that uses the name of the provider. These functions must accept *args and **kwargs and will return a JSON-serializable object through json.dumps() method, for example a ping function:

def ping(*args, **kwargs):
    return {'pong': True}

By default Django status provides the follow checks:

Ping

A ping to application. URL: /api/health/ping

Databases

Check if databases are running. URL: /api/health/databases

Caches

Check if caches are running. URL: /api/health/caches

Celery

Check if celery workers defined in settings are running. URL: /api/health/celery

Databases stats

Show stats for all databases. URL: /api/stats/databases

Celery stats

Show celery worker stats. URL: /api/stats/celery

Code

Source code stats such as current active branch, last commit, if debug is active… URL: /api/stats/code

Django Status website

A website that shows Django Status data is available in this application. It’s possible access to follow URLs to get a detailed view of your system status. Those three pages will show results of providers configured (as explained in settings section):

http://www.website.com/status/
http://www.website.com/status/health/
http://www.website.com/status/stats/

Django Status API

Django Status API can be used as a standalone application including only their urls:

urlpatterns = [
    ...
    url(r'^status/', include('status.api.urls')),
]

This API have a single url for each provider, that are grouped by resources. Each provider can be queried alone, returning his current status:

http://your_domain/status/api/health/ping

Also there is a resource view that will return the status of all providers:

http://your_domain/status/api/health

For last, there is a root view that will return the status of all providers from all resources:

http://your_domain/status/api

Django management commands

Django Status provides a django management command to query current status of a resource. This command can be call as:

python manage.py status <resource> [options]

To get current status of health checks, and exit with an error if some check is failing:

python manage.py status health -e

Each resource has its own set of options that can be displayed through command help:

python manage.py status -h

Command

Previous Django command can be used in standalone mode as:

django_status <resource> [options]

Settings

STATUS_CHECK_PROVIDERS

List of additional check providers. Each provider consists in a tuple of name, function complete path, args and kwargs. Example:

STATUS_PROVIDERS = {
    'resource': (
        ('test', 'application.module.test_function', [1, 2], {'foo': 'bar'}),
    )
}

Default:

PROVIDERS = getattr(settings, 'STATUS_PROVIDERS', {
    'health': (
        ('ping', 'status.providers.health.ping', None, None),
        ('databases', 'status.providers.django.health.databases', None, None),
        ('caches', 'status.providers.django.health.caches', None, None),
    ),
    'stats': (
        ('databases', 'status.providers.django.stats.databases', None, None),
        ('code', 'status.providers.stats.code', None, None),
    )
}

STATUS_CELERY_WORKERS

List of hostname from celery workers to be checked. If any worker is defined, two additional providers listed previously will be added to default set. Default:

STATUS_CELERY_WORKERS = ()

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-status-2.2.1.tar.gz (899.4 kB view details)

Uploaded Source

Built Distribution

django_status-2.2.1-py2.py3-none-any.whl (928.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-status-2.2.1.tar.gz.

File metadata

File hashes

Hashes for django-status-2.2.1.tar.gz
Algorithm Hash digest
SHA256 7a62715663060c4f3937273383fe65f56efd4182e0274581ac78851288292e5b
MD5 e6fc937dc7db914fb1cd99496b5a8e22
BLAKE2b-256 1f2c80a183a46b33afa965f01d39ef5b29a57563d85e0759ca66987230d22a3b

See more details on using hashes here.

File details

Details for the file django_status-2.2.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_status-2.2.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b4f77fe565c2813f179d917b7024de333d794b92fe8c780846a1499ec976c776
MD5 61a805d9cb78603e9d09e73e76e1b873
BLAKE2b-256 93deb88996d261fccb93ef33ab3e1ee6290ffc088b8357017527b87d05af5ea7

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