Skip to main content

Alliance Auth plugin for monitoring celery tasks

Project description

Task Monitor

An Alliance Auth app for monitoring celery tasks.

release python django pipeline codecov license pre-commit Code style: black chat

Contents

Features

Task Monitor enables administrators to monitor celery tasks running on their system.

  • Creates a log of all recently executed celery tasks including failed and retried tasks.
  • Stores many details in task logs to support the analysis of potential celery issues, including the parameters a task with called with and complete exception messages
  • Keeps the storage needs in check by automatically deleting older task logs and removing likely bloat from the collected data (but can also be turned off)
  • Admins can investigate task log with search & filters
  • Admins can view details for each task incl. exceptions and trace logs
  • Admins can review reports with charts providing answers to common questions, e.g:
    • How many tasks have failed/retried?
    • How many tasks where run by each of my apps?
    • Which are the most frequent tasks?
    • Which tasks have the longest runtime?
    • Which tasks failed the most?
  • Admins can export all task logs to a CSV file for further analysis with 3rd party tools (e.g. Google sheets)

Screenshots

Full log of all recently executed tasks

tasklog

View details for each task incl. exception tracelogs

tasklog

Example chart in reports

tasklog

Installation

Step 1 - Check prerequisites

Task Monitor is a plugin for Alliance Auth. If you don't have Alliance Auth running already, please install it first before proceeding. (see the official AA installation guide for details)

Step 2 - Install app

Make sure you are in the virtual environment (venv) of your Alliance Auth installation. Then install the newest release from PyPI:

pip install aa-taskmonitor

Step 3 - Configure Auth settings

Configure your Auth settings (local.py) as follows:

  • Add 'taskmonitor' to INSTALLED_APPS
  • Optional: Add additional settings if you want to change any defaults. See Settings for the full list.

Step 4 - Finalize App installation

Run migrations & copy static files

python manage.py migrate
python manage.py collectstatic --noinput

Restart your supervisor services for Auth.

Settings

Here is a list of available settings for this app. They can be configured by adding them to your AA settings file (local.py).

Note that all settings are optional and the app will use the documented default settings if they are not used.

Name Description Default
TASKMONITOR_DATA_MAX_AGE Max age of logged tasks in hours. Older logs be deleted automatically. 24
TASKMONITOR_HOUSEKEEPING_FREQUENCY Frequency of house keeping runs in minutes. 15
TASKMONITOR_QUEUED_TASKS_CACHE_TIMEOUT Timeout for caching queued tasks in seconds. 60
TASKMONITOR_REPORTS_MAX_AGE Max age of cached reports in minutes. 15
TASKMONITOR_REPORTS_MAX_TOP Max items to show in the top reports. e.g. 10 will shop the top ten items. 15
TASKMONITOR_TRUNCATE_NESTED_DATA Whether deeply nested task params and results are truncated. Please see FAQ for details. True

FAQ

Is it possible to store task logs longer then for just 24 hours?

Yes, there is a setting, which you can increase according to your needs. However, please keep in mind that your storage needs will increase accordingly. The current approx. usage is 0.5 KB per entry, so e.g. you need approx. 500 MB to store 1.000.000 task logs.

How is this app different from celery analytics?

Celery Analytics seams to be designed mainly as data source for reports on Grafana. It apparently works great if you want to integrate analysis about your task executions into a Grafana dashboards. But it's usability without Grafana is limited.

Task Monitor on the other hand aims to be fully functional standalone by providing reports and many useful features for analyzing your task logs directly on the admin site. It also provides a more complete picture, since Celery Analytics ignores retried tasks.

How is this app different from celery's flower?

Flower offers more detailed and technical information about task runs and might therefore be more most for developers. However, it not designed to store a larger number of task logs (default is only 10K) and is appears therefore to be less suited for Alliance Auth, where you typically have 100K+ tasks per day.

What does data truncating do exactly?

Task Monitor has data truncating enabled by default. It is applied when storing args, kwargs and results in task logs. This helps to reduce the storage consumptions and also makes the task log better readable. But it can be turned off.

Task args are truncated by clearing all nested containers.

Example: [1, [2, 3], 4] becomes [1, [], 4]

Task kwargs are truncated by clearing all nested containers in values.

Example: {"a": [1, 2], "b": 3} becomes {"a": [], "b": 3}

Finally, task results are truncated like args and kwargs depending on their type. In addition lists of empty containers are compressed.

Example: [ [], [], [] ] becomes []

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

aa-taskmonitor-0.9.1.tar.gz (393.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aa_taskmonitor-0.9.1-py3-none-any.whl (417.7 kB view details)

Uploaded Python 3

File details

Details for the file aa-taskmonitor-0.9.1.tar.gz.

File metadata

  • Download URL: aa-taskmonitor-0.9.1.tar.gz
  • Upload date:
  • Size: 393.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.16

File hashes

Hashes for aa-taskmonitor-0.9.1.tar.gz
Algorithm Hash digest
SHA256 9bd3a20b1fc7799c1b8b7cfa6bc45667d9ad62a52fee20619b7ace941cffdba4
MD5 da9942c4d9a752b0e4a48c1b206f70ba
BLAKE2b-256 dc9f23505fa9c3f12bcdc950db609a6ff7beaf48eda3a465a738a912caa443a1

See more details on using hashes here.

File details

Details for the file aa_taskmonitor-0.9.1-py3-none-any.whl.

File metadata

  • Download URL: aa_taskmonitor-0.9.1-py3-none-any.whl
  • Upload date:
  • Size: 417.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.16

File hashes

Hashes for aa_taskmonitor-0.9.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8fd59efb335bbb4cfd60cf7a771f77d991a369216c27260d0150acd052656682
MD5 28818fae4d266ed015e7017fecdbd778
BLAKE2b-256 361b35aadec2732864b8de7a635635788b95473b12f816e19e4fc3ba56974d83

See more details on using hashes here.

Supported by

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