Skip to main content

Celery + Redis task queue with admin UI for monitoring and retrying failed/stuck tasks

Project description

simple_module_background_tasks

Celery + Redis background-task module for simple_module apps. Provides a pre-configured Celery instance, a task registration hook, and an admin UI for monitoring + retrying failed/stuck tasks.

Install

pip install simple_module_background_tasks

Requires a Redis broker — set SM_CELERY_BROKER_URL (default redis://localhost:6379/0).

What it provides

  • register_background_tasks() module hook — modules declare tasks here; the registry wires them into the Celery app at boot.
  • Admin UI at /background-tasks/admin — list recent runs, retry failed, inspect tracebacks.
  • Shared Celery app accessible via from background_tasks import celery_app (import name background_tasks, distribution name simple_module_background_tasks).

Usage

Declare a task in a module:

# modules/reports/reports/tasks.py
from background_tasks import celery_app   # type: ignore[import-not-found]


@celery_app.task(name="reports.generate")
def generate_report(report_id: int) -> None:
    ...

Register it:

class ReportsModule(ModuleBase):
    meta = ModuleMeta(name="reports", depends_on=["background_tasks"])

    def register_background_tasks(self):
        from . import tasks  # noqa: F401 — side-effect: registers tasks

Enqueue from an endpoint:

generate_report.delay(report_id=42)

Run a worker locally:

uv run celery -A background_tasks.celery_app worker --loglevel=info

Depends on

  • simple_module_core, simple_module_db, simple_module_hosting
  • celery[redis]>=5.4, redis>=5

License

MIT — see LICENSE.

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

simple_module_background_tasks-0.0.1.tar.gz (27.7 kB view details)

Uploaded Source

Built Distribution

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

simple_module_background_tasks-0.0.1-py3-none-any.whl (34.6 kB view details)

Uploaded Python 3

File details

Details for the file simple_module_background_tasks-0.0.1.tar.gz.

File metadata

File hashes

Hashes for simple_module_background_tasks-0.0.1.tar.gz
Algorithm Hash digest
SHA256 d71e2b8a09b25fa4d7dc18a7b5cf31fc12f663f6870269424b33ba40e81486db
MD5 01782f6d9b9ed03c5f199b5798653f62
BLAKE2b-256 60af4531c3814027aff3dda8b570e9942f7a52ebeea7d888480ed4585a4cd394

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_background_tasks-0.0.1.tar.gz:

Publisher: release.yml on antosubash/simple_module_python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file simple_module_background_tasks-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_module_background_tasks-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 827422767774628edca66e5befb6abf22a30666521b900a14ba856da3e14e61e
MD5 f8859da465c85bce92285715cbb72f13
BLAKE2b-256 8bf3ed42d3658a3853c3517fcb5e9eeb0c45ed3f02b8934ba6e526a96473a3fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_module_background_tasks-0.0.1-py3-none-any.whl:

Publisher: release.yml on antosubash/simple_module_python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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