1.安装django-celery

  pip install django-celery

2.添加配置 demos/demos/settings.py(我的项目名为demos,这里只是示范,切勿搞混)

# celery 相关配置
# 配置celery时区,默认时UTC。
CELERY_TIMEZONE = TIME_ZONE # 任务队列的链接地址 celery配置redis作为broker。redis有16个数据库,编号0~15。
CELERY_BROKER_URL = 'redis://127.0.0.1:6379/2' # 设置存储结果的后台 结果队列的链接地址
CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/3' # 可接受的内容格式
CELERY_ACCEPT_CONTENT = ["json"]
# 任务序列化数据格式
CELERY_TASK_SERIALIZER = "json"
# 结果序列化数据格式
CELERY_RESULT_SERIALIZER = "json"

在项目同名目录下创建 demos/demos/celery.py(必须按照要求来)

from __future__ import absolute_import, unicode_literals
import os
from celery import Celery # 指定Django默认配置文件模块
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'demos.settings') # 为项目demos创建一个Celery实例。
app = Celery('demos') # 这里指定从django的settings.py里读取celery配置,且setting中的配置文件必须以'CELERY_'开头
app.config_from_object('django.conf:settings', namespace='CELERY') # 自动从所有已注册的django app中加载任务
app.autodiscover_tasks()

在已经注册app目录中,创建名为tasks.py的文件(如果取别的名字,celery就扫描不到了)

将程序导入项目同名目录下的dmos/demos/init.py中

from __future__ import absolute_import, unicode_literals

from .celery import app as celery_app

__all__ = ('celery_app',)

3.启动worker

1.先启动redis server

  2.cd到项目目录

     celery -A demos worker --loglevel=INFO

   windows用户:celery -A demos worker --loglevel=INFO -P eventlet

我的版本是,python3.9+django4.0+celery5.0+redis5.0

如果是按照上述方法执行,还有报错,那就极有可能是版本不兼容的问题了。建议去官方文档查看!

4.celery定时任务

from django.shortcuts import HttpResponse
from api import tasks
import datetime def create_task(request):
# 1.立即执行
# result = tasks.add.delay(2, 2) # 2.定时执行
# 获取当前的本地时间
ctime = datetime.datetime.now()
# 本地时间转换为utc时间
utc_ctime = datetime.datetime.utcfromtimestamp(ctime.timestamp())
# 当前utc时间加十秒
utc10 = datetime.timedelta(seconds=10)
# 得到目标时间
target_time = utc_ctime + utc10
# 调用函数,传入参数,以及函数执行时间
result = tasks.add.apply_async(args=[20, 3], eta=target_time) return HttpResponse(result.id)
def get_result(request):
"""
result_object.status # 获取状态
result_object.get() # 获取数据
result_object.forget() # 把数据在backend中移除
result_object.revoke() # 取消任务
result_object.revoke(terminate=True) # 强制取消任务
"""
nid = request.GET.get('nid') from celery.result import AsyncResult
from demos import celery_app result_object = AsyncResult(id=nid, app=celery_app) if result_object.successful():
data = result_object.get()
result_object.forget()
return HttpResponse(data)
elif result_object.failed():
pass else:
pass

Django-django-celery的配置的更多相关文章

  1. django集成celery

    Celery是一个基于分布式消息传递的开源异步任务队列,在django实际应用场景下,往往有一些较为耗时,但并不需要返回值的任务, 例如发送邮件,更新我们自己的统计数据库,这时我们可以将这些任务交由c ...

  2. Django中Celery的实现介绍(一)

    Django中Celery的实现 Celery官网http://www.celeryproject.org/ 学习资料:http://docs.jinkan.org/docs/celery/ Cele ...

  3. django和celery结合应用

    django+celery项目结构 - project_name - app01 - __init__.py - admin.py - views.py - modes.py - tasks.py # ...

  4. Django中Celery http请求异步处理(四)

    Django中Celery http请求异步处理 本章延续celery之前的系列 1.settings配置 2.编写task jib_update_task任务为更新salt jid数据 3.url设 ...

  5. Django 使用 Celery 实现异步任务

    对于网站来说,给用户一个较好的体验是很重要的事情,其中最重要的指标就是网站的浏览速度.因此服务端要从各个方面对网站性能进行优化,比如可采用CDN加载一些公共静态文件,如js和css:合并css或者js ...

  6. 4.Django使用celery

    1. 配置celery   创建django项目celery_demo, 创建应用demo: django-admin startproject celery_demo python manage.p ...

  7. Django使用Celery进行异步任务

    Celery Celery是一个功能完备即插即用的异步任务队列系统.它适用于异步处理问题,当发送邮件.或者文件上传, 图像处理等等一些比较耗时的操作,我们可将其异步执行,这样用户不需要等待很久,提高用 ...

  8. django、celery异步发邮件

    django.celery异步发邮件 django自带的send_mail发邮件功能执行发邮件功能会因为网络的原因造成花费的时间过长,为了解决这个问题,可以用celery + redis代替 安装包: ...

  9. python django与celery的集成

    一.celery与django 关于celery介绍和使用可以查看上篇Python中任务队列-芹菜celery的使用 关于django的介绍和使用可查看python django框架+vue.js前后 ...

  10. django 1.8 日志配置

    django 1.8 日志配置 以下为setings配置logging代码片段 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(_ ...

随机推荐

  1. XShell 连接 VMware Linux

    如果你的系统是 Ubuntu,并且是精简安装的系统,极大可能使用ifconfig时会提示你安装相关依赖,所以你安装的时候要记得顺带安装 ifconfig: sudo apt install ifcon ...

  2. Postgresql执行计划浅析与案例

    一.前言 PostgreSQL为每个收到查询产生一个查询计划. 选择正确的计划来匹配查询结构和数据的属性对于好的性能来说绝对是最关键的,因此系统包含了一个复杂的规划器来尝试选择好的计划. 你可以使用E ...

  3. 《爆肝整理》保姆级系列教程-玩转Charles抓包神器教程(9)-Charles如何修改请求参数和响应数据-上篇

    1.简介 宏哥之前一直用postman调接口比较多(web端),也非常容易上手和操作.但有时候想要去修改APP的页面展示,造数据又会比较麻烦,你自己造相对还好些,要是让开发造,还得低眉顺眼的去求人.通 ...

  4. git 日常基本使用

    // 将远程仓库下的所有分支拉取到本地 git fetch origin // 将dev分支合并到当前所在的分支 git merge dev // 基于当前分支克隆出新的本地分支 git checko ...

  5. 通过docker 安装部署sentry

    一.下载项目 git clone https://github.com/getsentry/self-hosted 二.安装 1.安装docker和docker-compose 2.运行sentry ...

  6. SAP SMARTFORMS World格式白屏

    解决方法: SE38 RSCPSETEDITOR 不勾选SAP script 和智能表

  7. Vulnhub:ReconForce-01.1靶机

    kali:192.168.111.111 靶机:192.168.111.200 信息收集 端口扫描 nmap -A -v -sV -T5 -p- --script=http-enum 192.168. ...

  8. 数值分析之数值积分 4.X

    求积公式 \[\int_{a}^{b} f(x) \mathrm{d} x \approx \sum_{k=0}^{n} A_{k} f\left(x_{k}\right) \] \(A_k\) 为求 ...

  9. ubuntu18 电脑重启后登录后无法进入桌面

    ubuntu18 电脑重启后登录后无法进入桌面 应该是ubuntu桌面管理器gdm3和nvidia驱动冲突导致的 解决办法: 首先卸载已有的nvidia驱动 注意:在下载完驱动后,此时电脑没有驱动文件 ...

  10. Property or method "scope" is not defined on the instance but referenced during render. Make sure that this property is reactive, either in the data option, or for class-based components

    报错如下 属性或方法"范围"不是在实例上定义的,而是在呈现期间引用的. 通过初始化属性,确保此属性是反应性的,无论是在数据选项中,还是对于基于类的组件. 原因在template中未 ...