34 lines
1.1 KiB
Python
34 lines
1.1 KiB
Python
import os
|
|
|
|
from celery import Celery
|
|
|
|
from evibes.settings import REDIS_PASSWORD, TIME_ZONE
|
|
|
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "evibes.settings")
|
|
|
|
app = Celery("evibes")
|
|
|
|
app.conf.update(
|
|
broker_url=f"redis://:{REDIS_PASSWORD}@redis:6379/0",
|
|
result_backend=f"redis://:{REDIS_PASSWORD}@redis:6379/0",
|
|
worker_hijack_root_logger=False,
|
|
worker_log_format="[%(asctime)s: %(levelname)s/%(processName)s] %(name)s: %(message)s",
|
|
worker_task_log_format="[%(asctime)s: %(levelname)s/%(processName)s] %(name)s: %(message)s",
|
|
worker_autoscale=(10, 3),
|
|
worker_prefetch_multiplier=1,
|
|
worker_max_tasks_per_child=100,
|
|
broker_connection_retry_on_startup=True,
|
|
timezone=TIME_ZONE,
|
|
task_serializer="json",
|
|
result_serializer="json",
|
|
result_compression="zlib",
|
|
accept_content=["json"],
|
|
broker_transport_options={
|
|
"retry_policy": {"interval_start": 0.1, "interval_step": 0.2, "max_retries": 5},
|
|
"visibility_timeout": 3600,
|
|
},
|
|
)
|
|
|
|
app.config_from_object("django.conf:settings", namespace="CELERY")
|
|
|
|
app.autodiscover_tasks()
|