Djiango配置Celery

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
相关推荐
常常有10 分钟前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao40 分钟前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_7488394942 分钟前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录42 分钟前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约1 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love2 小时前
MySQL的执行流程
android·数据库·mysql
程序leo源2 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
这个DBA有点耶2 小时前
COUNT进阶:超大表的近似计数与HyperLogLog
数据库·sql·程序人生·学习方法·dba·改行学it
武子康3 小时前
调查研究-138 全球机器人产业深度调研报告【01 篇】:市场规模、竞争格局与商业化成熟 2026
服务器·数据库·ai·chatgpt·机器人·具身智能
zhojiew3 小时前
在本地PostgreSQL使用pgvector构建生成式 AI 应用的实践
数据库·人工智能·postgresql