Django和celery的使用

本文介绍了在Python 3.5和Django 1.8环境下,如何配置和使用Django与Celery进行异步任务处理。内容涵盖版本选择、相关包依赖、项目目录结构、settings与celeryconfig配置、tasks编写方式、views与urls的结合、定时任务设定以及Celery命令行工具的使用。
摘要由CSDN通过智能技术生成

一、版本问题:
python3.6以上的版本,djcelery包加入以后启动会报错,暂时不会修改,所以用的是python3.5的版本,亲测可以使用。
相关包如下:
amqp 1.4.9
anyjson 0.3.3
billiard 3.3.0.23
celery 3.1.26.post2
Django 1.8
django-celery 3.3.1
django-celery-results 1.2.1
flower 0.9.5
humanize 2.6.0
importlib-metadata 2.0.0
kombu 3.0.37
pip 20.2.3
prometheus-client 0.8.0
PyMySQL 0.10.1
pytz 2020.1
redis 2.10.6
setuptools 50.3.0
sqlparse 0.4.1
supervisor 4.2.1
tornado 5.1.1
vine 1.3.0
wheel 0.35.1
zipp 1.2.0

二、总体目录架构:
在这里插入图片描述

三、setting的配置问题:

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'djcelery',
    'apps'
]

from .celeryconfig import *
BROKER_BACKEND = 'redis'
BROKER_URL = 'redis://127.0.0.1:6379/1'
CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/2'

四、celeryconfig的配置问题

import djcelery
from datetime import timedelta
djcelery.setup_loader()

CELERY_IMPORTS = ["apps.tasks"]

CELERY_QUEUE
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Django-Celery是一个用于在Django应用中集成Celery任务队列的插件。它允许你将耗时的任务异步执行,从而提高应用的性能和响应速度。下面是一些使用Django-Celery的步骤: 1. 安装CeleryDjango-Celery:首先,确保你已经安装了CeleryDjango-Celery。你可以通过运行以下命令来安装它们: ``` pip install celery django-celery ``` 2. 配置Celery:在Django项目的`settings.py`文件中,添加以下配置: ```python # settings.py # 配置Celery Broker(消息代理) BROKER_URL = 'amqp://guest:guest@localhost:5672//' # 配置Celery Backend(结果存储) CELERY_RESULT_BACKEND = 'db+sqlite:///results.sqlite' # 配置Celery Beat(定时任务) CELERY_BEAT_SCHEDULER = 'django_celery_beat.schedulers.DatabaseScheduler' ``` 请根据你的实际情况修改上述配置。 3. 创建Celery App:在你的Django项目中,创建一个名为`celery.py`的文件,并添加以下代码: ```python # celery.py from celery import Celery app = Celery('your_project_name') # 配置Celery app.config_from_object('django.conf:settings', namespace='CELERY') # 自动从Django app中加载任务 app.autodiscover_tasks() ``` 确保将`your_project_name`替换为你的项目名称。 4. 创建任务:在Django app中创建一个任务。例如,你可以在你的app目录下创建一个名为`tasks.py`的文件,并添加以下代码: ```python # tasks.py from celery import shared_task @shared_task def add(x, y): return x + y ``` 这是一个简单的任务示例,将两个数字相加并返回结果。 5. 启动Celery Worker:运行以下命令来启动Celery worker: ``` celery -A your_project_name worker --loglevel=info ``` 确保将`your_project_name`替换为你的项目名称。 6. 调用任务:在你的Django应用程序中,你可以通过导入任务函数并调用它来触发任务的执行。例如: ```python from your_app.tasks import add result = add.delay(1, 2) ``` 这里使用了`delay()`方法来异步调用任务。你也可以使用`apply_async()`方法来更精确地控制任务的执行。 这些是使用Django-Celery的基本步骤。你还可以配置更多高级选项,如任务重试、任务结果存储等。请参考Django-Celery的官方文档以获取更多详细信息。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值