django tasks manager
v1.0.1
매우 간단한 Django & Celery 통합 -이 라이브러리는 AppSeed가 적극적으로 지원합니다.
특징:
Celery Tasks 만들거나 취소합니다View LOGSMinimal Configurationusers_in_db() - 등록 된 모든 사용자를 나열합니다execute_script() - 사용자가 CELERY_SCRIPTS_DIR (cfg 매개 변수)에 정의 된 스크립트를 실행하도록합니다.
PIP통해 패키지를 설치하십시오
$ pip install django-tasks-manager
// OR
$ pip install git+https://github.com/app-generator/django-tasks-manager.git새로운 라우팅을 포함하십시오
# core/urls.py
from django . urls import path , include # <-- UPDATE: Add 'include' HELPER
urlpatterns = [
...
path ( "" , include ( "django_tm.urls" )), # <-- New Routes
...
]스크립트 및 로그 디렉토리 만들기 - 재구성 된 장소는 프로젝트의 근원에 있습니다.
$ mkdir celery_scripts # Used in Settings -> CELERY_SCRIPTS_DIR
$ mkdir celery_logs # Used in Settings -> CELERY_SCRIPTS_DIR구성 구성 업데이트
os객체 가져 오기 추가
import os # <-- NEW구성 업데이트 : 새 앱을 포함시킵니다
INSTALLED_APPS = [
...
'django_tm' , # Django Tasks Manager # <-- NEW
'django_celery_results' , # Django Celery Results # <-- NEW
]구성 업데이트 : 새 템플릿을 포함하십시오
TEMPLATE_DIR_TASKS = os . path . join ( BASE_DIR , "django_tm/templates" ) # <-- NEW
TEMPLATES = [
{
'BACKEND' : 'django.template.backends.django.DjangoTemplates' ,
'DIRS' : [ TEMPLATE_DIR_TASKS ], # <-- Updated
'APP_DIRS' : True ,
},
]구성 업데이트 : 새 Celery_ 섹션
#############################################################
# Celery configurations
# https://docs.celeryq.dev/en/stable/django/first-steps-with-django.html
# !!!
# BASE_DIR points to the ROOT of the project
# Note: make sure you have 'os' object imported
# !!!
# !!!
# BASE_DIR = os.path.dirname(os.path.dirname(__file__))
# !!!
# Working Directories required write permission
CELERY_SCRIPTS_DIR = os . path . join ( BASE_DIR , "celery_scripts" )
CELERY_LOGS_DIR = os . path . join ( BASE_DIR , "celery_logs" )
CELERY_BROKER_URL = os . environ . get ( "CELERY_BROKER" , "redis://localhost:6379" )
CELERY_RESULT_BACKEND = os . environ . get ( "CELERY_BROKER" , "redis://localhost:6379" )
CELERY_TASK_TRACK_STARTED = True
CELERY_TASK_TIME_LIMIT = 30 * 60
CELERY_CACHE_BACKEND = "django-cache"
CELERY_RESULT_BACKEND = "django-db"
CELERY_RESULT_EXTENDED = True
CELERY_RESULT_EXPIRES = 60 * 60 * 24 * 30 # Results expire after 1 month
CELERY_ACCEPT_CONTENT = [ "json" ]
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
#############################################################
#############################################################앱을 시작하십시오
$ # Set up the database
$ python manage.py makemigrations
$ python manage.py migrate
$
$ # Create the superuser
$ python manage.py createsuperuser
$
$ # Start the application (development mode)
$ python manage.py runserver # default port 8000superuser 로 인증하십시오Tasks 페이지에 액세스하십시오 : http://127.0.0.1:8000/tasksCelery Manager (다른 터미널) 및 업데이트 환경을 시작하십시오
manage.py 에 제공된 값을 사용하여 DJANGO_SETTINGS_MODULE 내보내십시오
$ export DJANGO_SETTINGS_MODULE=cfg.settings 사용 된 수출 가치는 manage.py 에서 가져와야합니다.
def main ():
"""Run administrative tasks."""
os . environ . setdefault ( "DJANGO_SETTINGS_MODULE" , "cfg.settings" ) # <-- VALUE to be exported
try :
from django . core . management import execute_from_command_line
except ImportError as exc :
... 참고 : Redis 서버는 포트 6379 (기본값)에서 예상됩니다. Redis가 다른 PORT 에서 실행되면 configuration : CELERY_BROKER_URL 및 CELERY_RESULT_BACKEND 업데이트하십시오.
$ celery --app=django_tm.celery.app worker --loglevel=info
View all tasks

View Task LOG

free sample :Project Creation (최소 파일 추가)Django 코어를 Install 및 생성합니다Django-TM (이 패키지) 설치Update ConfigurationStart the appTasks Manager 사용하십시오Django Tasks Manager- AppSeed 가 제공하는 오픈 소스 라이브러리