Celery与Django的结合
一、什么是Celery
Celery 是一个 基于python开发的分布式异步消息任务队列,通过它可以实现任务的异步处理以及定时任务的处理,它的基本工作流程是:
- 先启动任务执行单元Worker,让它一直监听消息中间件中是否有任务
- 客户端可以发布异步任务和定时任务
- 通过Celery将上述任务添加到消息中间件(可以使用rabbitMQ或者Redis)
- 此时Worker可以监听到中间件中有任务,进行执行任务
- 执行完毕后任务结果就放到Backend中(可以使用Redis或者Mysql)
这里主要讨论在Django中如何使用Celery来执行异步任务和定时任务。
二、Django中执行异步任务
1、环境配置
需要注意的是包之间的兼容性
pip install celery == 4.3.0 pip install eventlet == 0.25.1 pip install redis == 3.2.0
2、创建Django项目
其目录结构如下:
- proj/
- manage.py
- proj/
- __init__.py
- settings.py
- urls.py
3、定义Celery实例
创建celery.py文件,位于proj/proj/celery.py
from __future__ import absolute_import, unicode_literals
import os
from celery import Celery
from django.conf import settings # set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'proj.settings') app = Celery('proj') # 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') # Load task modules from all registered Django app configs.
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS) @app.task(bind=True)
def debug_task(self):
print('Request: {0!r}'.format(self.request))
4、导入Celery实例
然后,需要将此上述Celery的实例导入到proj/proj/__init__.py
模块中。这样可以确保在Django启动时加载该应用,以便@shared_task
装饰器将使用该应用:
from __future__ import absolute_import, unicode_literals # This will make sure the app is always imported when
# Django starts so that shared_task will use this app.
from .celery import app as celery_app __all__ = ('celery_app',)
5、在Django配置文件中配置Celery参数
位于:proj/proj/settings.py
... CELERY_BROKER_URL = 'redis://127.0.0.1:6379/0' # Broker配置,使用Redis作为消息中间件 CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/0' # BACKEND配置,这里使用redis CELERY_RESULT_SERIALIZER = 'json' # 结果序列化方案 ...
6、创建异步任务
在每一个app下创建tasks.py文件,如下图所示:
这样Celery会自动发现每一个app下的tasks.py文件,在这个文件中写入的就是需要执行的异步任务,相当于Worker。
# Create your tasks here
from __future__ import absolute_import, unicode_literals
from celery import shared_task @shared_task
def add(x, y):
print(x+y)
return x + y @shared_task
def mul(x, y):
return x * y @shared_task
def xsum(numbers):
return sum(numbers)
7、在Django的视图中添加任务,获取结果
from django.shortcuts import render,HttpResponse
from app01.tasks import add,mul
# Create your views here. #异步任务
def celery_test(request):
#delay相当于将异步任务add加入到Broker
task = add.delay(4,22)
#从Backend中获取执行任务的结果
res = task.get()
print(res)
return HttpResponse(task)
8、执行异步任务
上述准备工作已经完毕,此时需要启动一个或多个worker进程来监听Broker是否有任务
#启动Worker
celery -A proj worker -l info -P eventlet
此时,已经监听Broker了;当访问对应url,执行celery_test函数,会执行到add.delay相当于将任务添加到Broker,这样在视图中可以操纵异步任务执行的结果了。
三、Django中执行定时任务
1、安装django-celery-beat
pip install django-celery-beat
2、Django配置文件添加django-celery-beat
INSTALLED_APPS = (
...,
'django_celery_beat',
)
3、生成对应的表
python manage.py migrate
此时,可以看到生成的一些表
注意,这些任务会自动从每一个app下的tasks中读取,只要是注册过的(用shared_task装饰过)
定时任务具体的时间需要在上述表中设定好,因为定时任务就是从数据库中这些表中读取的
4、启动定时任务
首先,还是需要启Worker,这与异步任务相同
celery -A proj worker -l info -P eventlet
然后需要再开启一个进程用于监听Broker里面的定时任务,到一定的时间,Worker执行
celery -A proj beat -l info -S django
值得注意的是每添加或修改一个任务,celery beat都需要重启一次
Celery与Django的结合的更多相关文章
- 异步任务队列Celery在Django中的使用
前段时间在Django Web平台开发中,碰到一些请求执行的任务时间较长(几分钟),为了加快用户的响应时间,因此决定采用异步任务的方式在后台执行这些任务.在同事的指引下接触了Celery这个异步任务队 ...
- 分布式队列celery 异步----Django框架中的使用
仅仅是个人学习的过程,发现有问题欢迎留言 一.celery 介绍 celery是一种功能完备的即插即用的任务对列 celery适用异步处理问题,比如上传邮件.上传文件.图像处理等比较耗时的事情 异步执 ...
- Using Celery with Django
参考1: http://docs.celeryproject.org/en/latest/django/first-steps-with-django.html#using-celery-with-d ...
- celery在Django中的集成使用
继上回安装和使用Redis之后,看看如何在Django中使用Celery.Celery是Python开发分布式任务列队的处理库.可以异步分布式地异步处理任务,也可定时执行任务等等.通常我们可以在Dja ...
- Celery在Django中的使用介绍
Celery在Django中的使用介绍 Celery简介 celery是一个简单.灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必须工具. 它是一个专注于实时处理的任务队列,同时也 ...
- Celery结合Django使用
一.Celery介绍 Celery 是一个 基于python开发的分布式异步消息任务队列,通过它可以轻松的实现任务的异步处理, 如果你的业务场景中需要用到异步任务,就可以考虑使用celery, 举几个 ...
- celery在Django中的应用
这里不解释celery,如果不清楚可以参考下面链接: http://docs.celeryproject.org/en/latest/getting-started/introduction.html ...
- Celery学习---Celery 与django结合实现计划任务功能
项目的目录结构: 项目前提: 安装并启动Redis 安装Django和Celery的定时任务插件 安装方法一: pip直接安装[安装了pip的前提下] omc@omc-virtual-machine: ...
- 使用celery执行Django串行异步任务
Django项目有一个耗时较长的update过程,希望在接到请求运行update过程的时候,Django应用仍能正常处理其他的请求,并且update过程要求不能并行,也不能漏掉任何一个请求 使用cel ...
随机推荐
- linux运维、架构之路-网络基础
一. 常用网络设备 1.交换机:实现多台主机之间互相通讯的需求 交换机实现互相通讯的要求: ①主机身份标识信息:mac地址,利用源mac和目标mac地址,进行身份信息识别 ②主机通过交换机识别目标主机 ...
- JS自定义随机数字键盘
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Leetcode_395. Longest Substring with At Least K Repeating Characters_[Devide and Conquer]
题目链接 对一个字符串,找出一个最长的子串长度,这个子串中所有字符出现的次数至少为k. 1.滑动窗口 一开始把题目看成了,子串中每个字符至多出现k次.如果是这样,那么是一道典型的滑动窗口的题目. 然而 ...
- spfa求次短路
思路:先算出每个点到1的最短路d1[i],记录下路径,然后枚举最短路上的边 删掉之后再求一遍最短路,那么这时的最短路就可能是答案. 但是这个做法是错误的,可以被卡掉. 比如根据下面的例题生成的一个数据 ...
- Http发送Json
public static JSONObject post(String url,JSONObject json){ HttpClient client = new DefaultHttpClient ...
- 利用 Skywalking 搭建 APM(应用性能管理)— 安装与配置
1.什么是 Skywalking Skywalking 是一个APM系统,即应用性能监控系统,为微服务架构和云原生架构系统设计.它通过探针自动收集所需的指标,并进行分布式追踪.通过这些调用链路以及指标 ...
- 【转】 C语言深度解剖读书笔记(1.关键字的秘密)
本文出处:http://blog.csdn.net/mbh_1991/article/details/10149805 开始本节学习笔记之前,先说几句题外话.其实对于C语言深度解剖这本书来说,看完了有 ...
- CET-6 分频周计划生词筛选(番外篇:百词斩)
点我阅读 番外-百词斩 2016.09.18 12:00pm transverse counterpart accessory cult gorgeous sediment assimilate st ...
- JavaScript.InjectedScriptHost
"use strict"; (function(InjectedScriptHost, inspectedGlobalObject, injectedScriptId) { ...
- Jenkins设置默用户为root
https://www.jianshu.com/p/181dfb259dc7 最近在需要在jenkins执行shell脚本,由于Jenkins之前是默认在线安装的,这样jenkins设置了默认用户je ...