>  기사  >  백엔드 개발  >  실용적인 전투: Celery, Redis 및 Django를 사용하여 동시 비동기 작업 구현

실용적인 전투: Celery, Redis 및 Django를 사용하여 동시 비동기 작업 구현

王林
王林원래의
2023-09-26 19:37:102125검색

실용적인 전투: Celery, Redis 및 Django를 사용하여 동시 비동기 작업 구현

실용: Celery, Redis 및 Django를 사용하여 동시 비동기 작업 구현

소개:
현대 웹 애플리케이션 개발에서 일부 장시간 작업(예: 데이터 처리, 이메일 보내기 등)을 위해 사용자 개선 경험과 시스템 성능을 향상시키기 위해 비동기 작업을 사용하여 이러한 작업을 처리하는 경우가 많습니다. 이 기사에서는 Celery, Redis 및 Django를 사용하여 동시 비동기 작업 솔루션을 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

1. Celery, Redis 및 Django 소개:

  1. Celery:
    Celery는 Python 애플리케이션에서 널리 사용되는 비동기 작업 대기열/메시지 미들웨어입니다. 시간이 많이 걸리는 작업을 기본 응용 프로그램에서 분리하여 시스템 성능을 향상시키는 간단한 방법을 제공합니다.
  2. Redis:
    Redis는 Celery의 메시지 브로커로 사용할 수 있는 고성능 인 메모리 데이터 구조 저장 시스템입니다. Celery는 작업의 비동기 실행을 달성하기 위해 Redis를 사용하여 작업 메시지를 저장합니다.
  3. Django:
    Django는 다양한 기능과 플러그인을 제공하는 Python 기반 웹 애플리케이션 개발 프레임워크입니다. Django의 구조와 패턴을 활용하여 비동기 작업을 구성 및 관리하고 Celery 및 Redis와 통합할 수 있습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.