Django的异步任务队列管理_Celery

1 基本原理

Celery 是一个异步任务队列,能够将耗时操作(如发邮件、处理图片、网络爬虫等)从 Django 主线程中分离出来,由后台的 worker 处理,避免阻塞请求。Celery 作为独立运行的后台进程(Worker),持续监听消息队列(Broker),接收并处理任务,而 Django 主线程用于发布任务。

Celery 是一种独立于 Django 的程序,通常需手动启动。它通过 Redis 等工具与主线程进行通信,并将任务进度和结果写入数据库,方便后续追溯。

基本流如下:

1.1 消息中间件 Broker

Django 和 Celery 通过消息中间件(Broker)进行通信,最常用的选择是 Redis 或 RabbitMQ,因为它们速度快且稳定。如果可以接受安装 Redis(在本地启动只需一条命令),建议直接使用它。当然,还可以考虑其他替代方案。

以批处理为例,时序图如下:

2 memory 方式实现

为了简化步骤,我先测试了 memory 方法。

2.1 安装 Celery

复制代码
$ pip install celery

2.2 加入项目

  • 创建 myproject/my_celery.py 文件,内容如下:

    import os
    from celery import Celery

    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings')

    app = Celery('myproject') # 注意改成自己的 myproject 名

    app.conf.broker_url = 'memory://'
    app.conf.result_backend = 'cache+memory://'

    app.autodiscover_tasks()

  • myproject/__init__.py 里加入:

    from .my_celery import app as celery_app all = ['celery_app']`

2.3 异步功能函数

添加异步功能:在应用的 tasks.py 中定义任务:

复制代码
from celery import shared_task

@shared_task
def add(x, y):
    print(f"Adding {x} + {y}")
    return x + y

调用异步功能:

复制代码
from myapp.tasks import add

add.delay(2, 3)

注意:由于 memory 维护不佳,建议直接使用 Redis。

3 redis 方式实现

3.1 使用 docker 方式安装 redis

复制代码
docker run -d --name redis-dev -p 6379:6379 redis

3.2 安装 redis 包

复制代码
pip install redis

3.3 修改代码

替换设置部分:

复制代码
app.conf.update(
    broker_url='redis://localhost:6379/0', # 如果在docker中使用,需要转换成宿主机ip
    result_backend='redis://localhost:6379/1',
    task_serializer='json',
    accept_content=['json'],
    timezone='Asia/Shanghai',
    enable_utc=True,
)

3.4 启动 celery

一般情况下,需要手动启动 celery 进程

复制代码
celery -A your_project worker --loglevel=info
相关推荐
程序设计实验室3 天前
分享一些2026年有意思的现代化Django生态组件
django
程序设计实验室4 天前
当人人都能用 AI 写代码时,我为什么选择重回 Django?
django·djangostarter
markfeng89 天前
Python+Django+H5+MySQL项目搭建
python·django
QQ40220549610 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
百锦再10 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
starlaky10 天前
Django入门笔记
笔记·django
QQ51100828510 天前
python+springboot+django/flask的校园资料分享系统
spring boot·python·django·flask·node.js·php
WeiXin_DZbishe10 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5
B站计算机毕业设计超人10 天前
计算机毕业设计Django+Vue.js高考推荐系统 高考可视化 大数据毕业设计(源码+LW文档+PPT+详细讲解)
大数据·vue.js·hadoop·django·毕业设计·课程设计·推荐算法
计算机程序猿学长10 天前
大数据毕业设计-基于django的音乐网站数据分析管理系统的设计与实现(源码+LW+部署文档+全bao+远程调试+代码讲解等)
大数据·django·课程设计