You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

celery-eye

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

celery-eye

Celery Eye - Django app to monitor and view Celery task logs in the admin panel

0.2.1
pipPyPI
Maintainers
1

Celery Eye

Celery Eye is a Django app that logs and displays Celery task execution details in the Django Admin panel. It enables developers and operators to monitor task history, status, and performance directly from the web UI.

🚀 Features

  • Logs all executed Celery tasks in real-time
  • View task name, status, start time, end time, and more
  • Admin interface to search, filter, and debug tasks
  • Lightweight and easy to integrate
  • Works with Redis and Celery 5+

📦 Installation

pip install celery-eye

🛠️ Prerequisites

Before installing celery-eye, ensure your Django project is already configured with Celery and Redis.

🔧 Project Setup

1. Configure celery.py

Create a celery.py file in your main Django project folder (same level as settings.py):

# myproject/celery.py
import os
from celery import Celery

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings')

app = Celery('myproject')
app.config_from_object('django.conf:settings', namespace='CELERY')
app.autodiscover_tasks()

2. Update __init__.py to initialize Celery

# myproject/__init__.py
from .celery import app as celery_app

__all__ = ['celery_app']

⚙️ settings.py Configuration

Add the following Celery and Redis configuration in your settings.py:

import os

# Celery Configuration
CELERY_BROKER_URL = os.getenv("CELERY_BROKER_URL", "redis://localhost:6379/0")
CELERY_ACCEPT_CONTENT = ["json"]
CELERY_TASK_SERIALIZER = "json"
CELERY_TIMEZONE = os.getenv("DEFAULT_TIMEZONE", "UTC")  # or your desired timezone
CELERY_LOG_DIR = BASE_DIR / "logs"  # or any path like "/var/logs/celery_eye/ or your path mount in your docker volumes"

Make sure you have Redis running locally or remotely.

🧩 Django Integration

1. Add celery_eye to INSTALLED_APPS

INSTALLED_APPS = [
    ...
    'celery_eye',
]

2. Configure MYPROJECT/urls.py

urlpatterns = [
    path("celery-eye/", include("celery_eye.urls")),
]

3. Run migrations

python manage.py migrate

4. Create a superuser (if you haven't)

python manage.py createsuperuser

5. Start your services

Make sure your services are running:

# Run Redis
redis-server

# Run Celery Worker (in your Django root directory)
celery -A myproject worker --loglevel=info

# Run Django server
python manage.py runserver

You should now be able to:

  • See Celery task execution logs in the Django Admin
  • Filter/search by status, task name, and timestamps

🧪 Example Task

# any_app/tasks.py
from celery import shared_task

@shared_task
def test_task(x, y):
    return x + y

Trigger in a Django shell:

python manage.py shell
from any_app.tasks import test_task
test_task.delay(5, 7)

🐳 Optional: Redis with Docker

You can spin up Redis with Docker:

docker run -d -p 6379:6379 redis

🤝 Contributing

Pull requests, issues, and feature suggestions are welcome!

📄 License

MIT License. See LICENSE for more details.

FAQs

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts