使用celery执行异步任务

  1. 下载celery,redis

pip3 install celery
#在这里我使用的是celery==4.2.2
#当celery版本过低的话celery配置可能会略有不同
#启动redis服务端
  • 在django项目的配置文件中配置返回值格式以及中间件IP

# Celery settings

CELERY_BROKER_URL = 'redis://localhost'

#: Only add pickle to this list if your broker is secured
#: from unwanted access (see userguide/security.html)
CELERY_ACCEPT_CONTENT = ['json']
CELERY_RESULT_BACKEND = 'redis://localhost'
CELERY_TASK_SERIALIZER = 'json'
  • 在django项目的项目文件夹下创建一个celery.py文件并写入如下代码

from __future__ import absolute_import, unicode_literals
import os
from celery import Celery

# 设置“celery”程序的默认Django设置模块。
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'demo.settings')

app = Celery('demo')
# 这里的demo表示你项目的名字

# Using a string here means the worker doesn't have to serialize
# the configuration object to child processes.
# - namespace='CELERY' means all celery-related configuration keys
# should have a `CELERY_` prefix.
app.config_from_object('django.conf:settings', namespace='CELERY')

# 从所有已注册的Django app configs加载任务模块
app.autodiscover_tasks()
  • 在我们app的views.py中写入如下代码

from django.shortcuts import render,HttpResponse
from .tasks import add
# Create your views here.
def index(request):
add.delay(1,2)
return HttpResponse('200 OK')
  • 在app中创建一个tasks.py文件用来放置任务

import time
from celery import Celery

celery_app = Celery('tasks', backend='redis://localhost', broker='redis://localhost')
# this is celery settings

# this is a function about need many time
@celery_app.task
def add(a, b):
time.sleep(5)
return a + b

然后我们就可以启动项目,并且启动celery的worker进程,并访问index路由

查看worker窗口是否正常执行

worker出现上图字样,没有ERROR字眼,就表示我们的celery已经准备就绪了,然后就可以进行访问查看worker是否正常处理异步操作

这样就表示我们的celery的异步执行任务就可以正常工作了

celery在win10上的坑

  • celery在win10上运行可能会出现`Celery ValueError: not enough values to unpack (expected 3, got 0)`这个报错`

  解决办法

  先安装一个eventlet

pip install eventlet

  在启动worker的时候加入一个参数

celery -A <mymodule> worker -l info -P eventlet

  然后就可以正常执行任务了

最新文章

  1. iOS总结:项目中的各种小坑汇总
  2. IOC框架整体介绍
  3. Lowest Common Ancestor of Two Nodes in a Binary Tree
  4. iOS 证书申请和使用详解(详细版)
  5. python-day6 常见算法 python内置模块
  6. C++学习43 输入输出有关的类和对象
  7. FMX架构图
  8. [Embed(source=&quot;asset.swf&quot;)] 使用其中的所有资源
  9. 【python之路6】pycharm的使用
  10. Java中数组Arrays.binarySearch,快速查找数组内元素位置
  11. HTML基础进阶
  12. Unity 使用 陀螺仪 实现 《王者荣耀》 登入界面 背景动态效果
  13. Arduino—运算符
  14. Hibernate 单向一对多映射
  15. Redis深入学习笔记(四)主从数据复制流程
  16. bower简明入门教程
  17. iOS Xcode 10: Multiple commands produce
  18. CentOS7安装Java还是无法使用javac
  19. shiro+SpringMVC 项目 配置404页面
  20. thinkphp中AJAX返回ajaxReturn()方法分析

热门文章

  1. bzoj4044/luoguP4762 [Cerc2014]Virus synthesis(回文自动机+dp)
  2. 有限差分法(Finite Difference Method)解方程:边界和内部结点的控制方程
  3. 在 Java 中 CycliBarriar 和 CountdownLatch 有什么区别?
  4. MySQL 根据JSON类型的字段进行过滤数据的方式
  5. ActiveMQ数据接收类型问题
  6. Redis的安装与启动(一)
  7. js的json序列化和反序列化
  8. java-关于getResourceAsStream
  9. django 三件套(render,redirect,HttpResponse)
  10. Netty学习摘记 —— 初识编解码器