Rumah >pembangunan bahagian belakang >Tutorial Python >Cara menggunakan Celery Redis Django untuk membangunkan pemproses tugas tak segerak berprestasi tinggi
Cara menggunakan Celery Redis Django untuk membangunkan pemproses tugas tak segerak berprestasi tinggi
Pengenalan:
Dalam pembangunan web moden, pemprosesan tugas tak segerak menjadi semakin penting. Pemprosesan segerak tradisional sering membawa kepada penurunan prestasi tapak web kerana permintaan lain disekat semasa memproses tugas yang memakan masa. Penggunaan pemproses tugas tak segerak boleh menyelesaikan masalah ini dengan berkesan dan meningkatkan prestasi laman web.
Artikel ini akan memperkenalkan cara menggunakan Celery, Redis dan Django untuk membangunkan pemproses tugas tak segerak berprestasi tinggi, dan memberikan contoh kod khusus.
1. Pemasangan dan konfigurasi Saderi:
# celery settings CELERY_BROKER_URL = 'redis://localhost:6379/0' CELERY_RESULT_BACKEND = 'redis://localhost:6379/0'
Nota: CELERY_BROKER_URL dan CELERY_RESULT_BACKEND gunakan Redis sebagai hujung belakang untuk broker mesej dan storan hasil.
2. Pemasangan dan konfigurasi Redis:
# redis settings REDIS_HOST = 'localhost' REDIS_PORT = 6379 REDIS_DB = 0
3. Tulis tugas tak segerak:
from celery import shared_task from django.core.mail import send_mail @shared_task def send_email_task(subject, message, recipient_list): send_mail(subject, message, 'noreply@example.com', recipient_list)
from .tasks import send_email_task def send_email_view(request): # 调用异步任务 send_email_task.delay('Subject', 'Message', ['recipient@example.com']) return HttpResponse('Email sent asynchronously.')
Keempat, mulakan Pekerja Saderi:
import os from celery import Celery from django.conf import settings os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project.settings') app = Celery('project') app.config_from_object('django.conf:settings', namespace='CELERY') app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
celery -A project.celery worker --loglevel=info
5. Pengujian dan penggunaan:
python manage.py runserver
6. Ringkasan:
Dengan menggunakan Celery, Redis dan Django, kami boleh melaksanakan pemproses tugas tak segerak berprestasi tinggi dengan mudah. Apabila membangunkan aplikasi web, anda boleh menggunakan pemproses tugas tak segerak untuk mengendalikan tugas yang memakan masa, meningkatkan prestasi tapak web dan meningkatkan pengalaman pengguna.
Di atas ialah pengenalan dan contoh kod khusus tentang cara menggunakan Celery, Redis dan Django untuk membangunkan pemproses tugas tak segerak berprestasi tinggi. Saya harap artikel ini berguna kepada anda, terima kasih kerana membaca!
Atas ialah kandungan terperinci Cara menggunakan Celery Redis Django untuk membangunkan pemproses tugas tak segerak berprestasi tinggi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!