1.安装依赖包
pip install celery
# 如果使用Redis作为消息代理
pip install redis
# 如果使用RabbitMQ作为消息代理
pip install pika
# 如果需要监控
pip install django-celery-results flower
# Django 5.1.6 + Celery 5.3.x + Redis 4.x
pip install django==5.1.6
pip install celery==5.3.6
pip install redis==4.6.0
pip install django-celery-results==2.5.1
pip install django-celery-beat==2.6.0
pip install eventlet
2.项目结构配置
myproject/
├── myproject/
│ ├── __init__.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
├── app01/
│ ├── views.py
│ ├── urls.py
│ ├── models.py
│ ├── test.py
├── mycelery/
│ ├── __init__.py
│ ├── config.py
│ ├── main.py
│ ├── sms/
│ │ ├── __init__.py
│ │ ├── tasks.py
│ ├── email/
│ │ ├── __init__.py
│ │ ├── tasks.py
├── manage.py
└── requirements.txt
3.配置文件
python
# myproject/mycelery/config.py
broker_url = 'redis://localhost:6379/15'
result_backend = 'redis://localhost:6379/14'
python
# myproject/mycelery/main.py
import os
# import sys
from celery import Celery
# 设置Django的默认设置模块
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings')
app = Celery('myproject')
# 从Django的设置文件中读取Celery配置
# app.config_from_object('django.conf:settings', namespace='CELERY')
app.config_from_object('mycelery.config')
# 自动发现所有Django app中的tasks.py
app.autodiscover_tasks(['mycelery.sms','mycelery.email'])
# 启动celery的命令
# 强烈建议切换目录到celery的根目录下启动
# pip install eventlet
# celery -A mycelery.main worker -l info -P eventlet
python
# myproject/mycelery/sms/tasks.py
from celery import shared_task
import logging
logger = logging.getLogger(__name__)
log = logging.getLogger('django')
@shared_task(bind=True, name='sms.import_product_info')
def import_product_info(self, goods_info):
# 异步逻辑编写
return "ok"
python
# myproject/app01/views.py
from mycelery.sms.tasks import import_product_info
def get(request):
import_product_info.delay(goods_info)
return Response("ok")
4.运行redis
redis-server.exe redis.windows.conf
5.运行celery
celery -A mycelery.main worker -l info -P eventlet