실용: Celery, Redis 및 Django를 사용하여 동시 비동기 작업 구현
소개:
현대 웹 애플리케이션 개발에서 일부 장시간 작업(예: 데이터 처리, 이메일 보내기 등)을 위해 사용자 개선 경험과 시스템 성능을 향상시키기 위해 비동기 작업을 사용하여 이러한 작업을 처리하는 경우가 많습니다. 이 기사에서는 Celery, Redis 및 Django를 사용하여 동시 비동기 작업 솔루션을 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.
1. Celery, Redis 및 Django 소개:
2. 환경 설정:
시작하기 전에 Python, Django, Celery 및 Redis가 설치되어 있는지 확인하세요. pip 명령을 사용하여 설치할 수 있습니다.
pip install django pip install celery pip install redis
3. Celery 및 Redis 구성:
Django 프로젝트의 구성 파일 settings.py에 다음 구성을 추가합니다.
# Celery配置 CELERY_BROKER_URL = 'redis://localhost:6379/0' CELERY_RESULT_BACKEND = 'redis://localhost:6379/0' # Redis配置 CACHES = { 'default': { 'BACKEND': 'redis_cache.RedisCache', 'LOCATION': '127.0.0.1:6379', 'OPTIONS': { 'DB': 0, 'PASSWORD': '', 'PARSER_CLASS': 'redis.connection.HiredisParser' }, } }
4. 비동기 생성 task:
Django 어딘가에 애플리케이션 디렉토리에 task.py 파일을 생성하고 다음 코드를 작성합니다:
from celery import shared_task @shared_task def send_email(email): """ 发送邮件的异步任务 """ # 发送邮件的代码 ...
5. 비동기 작업 호출:
Django의 뷰 함수에서 지연() 메서드를 통해 비동기 작업을 호출합니다.
from .tasks import send_email def send_email_view(request): # 获取需要发送邮件的用户邮箱 email = request.GET.get('email') # 调用异步任务 send_email.delay(email) # 返回响应 return JsonResponse({'status': 'success'})
6. Celery Worker 및 Beat 시작:
프로젝트 루트 디렉터리의 celery.py 파일에 다음 코드를 작성합니다.
from __future__ import absolute_import import os from celery import Celery # 设置Django环境变量 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project.settings') app = Celery('project') app.config_from_object('django.conf:settings', namespace='CELERY') app.autodiscover_tasks()
그런 다음 프로젝트 루트 디렉터리에서 다음 명령을 실행하여 Celery Worker를 시작합니다. and Beat:
celery -A project worker --loglevel=info celery -A project beat --loglevel=info
7. 비동기 작업 테스트:
Django 테스트 뷰 함수를 작성하고 비동기 작업을 호출하여 테스트합니다. 예제는 다음과 같습니다.
from .tasks import send_email def test_view(request): # 调用异步任务 send_email.delay('test@example.com') # 返回响应 return JsonResponse({'status': 'success'})
8 요약:
이 글에서는 Celery, Redis 사용 방법을 소개합니다. 그리고 Django는 동시 비동기 작업을 구현합니다. Celery 및 Redis를 구성하면 장시간 작업을 비동기식으로 실행하여 시스템 성능과 사용자 경험을 향상시킬 수 있습니다. 동시에 독자의 참조와 연습을 위해 구체적인 코드 예제가 제공됩니다. 이 솔루션 세트를 배우고 실습함으로써 독자는 자신의 프로젝트에 동시 비동기 작업을 합리적으로 적용할 수 있다고 믿습니다.
위 내용은 실용적인 전투: Celery, Redis 및 Django를 사용하여 동시 비동기 작업 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!