Django celery6.4

网友投稿 820 2022-05-30

celery

官方网站

中文文档

示例一:用户发起request,并等待response返回。在本些views中,可能需要执行一段耗时的程序,那么用户就会等待很长时间,造成不好的用户体验

示例二:网站每小时需要同步一次天气预报信息,但是http是请求触发的,难道要一小时请求一次吗?

使用celery后,情况就不一样了

示例一的解决:将耗时的程序放到celery中执行

示例二的解决:使用celery定时执行

名词

任务task:就是一个Python函数

队列queue:将需要执行的任务加入到队列中

工人worker:在一个新进程中,负责执行队列中的任务

代理人broker:负责调度,在布置环境中使用redis

使用

安装包

celery==3.1.25

celery-with-redis==3.0

Django celery6.4

django-celery==3.1.17

配置settings

INSTALLED_APPS = (

...

'djcelery',

}

...

import djcelery

djcelery.setup_loader()

BROKER_URL = 'redis://127.0.0.1:6379/0'

CELERY_IMPORTS = ('应用名称.task')

在应用目录下创建task.py文件

import time

from celery import task

@task

def sayhello():

print('hello ...')

time.sleep(2)

print('world ...')

迁移,生成celery需要的数据表

python manage.py migrate

启动Redis

sudo redis-server /etc/redis/redis.conf

启动worker

python manage.py celery worker --loglevel=info

调用语法

function.delay(parameters)

使用代码

#from task import *

def sayhello(request):

print('hello ...')

import time

time.sleep(10)

print('world ...')

# sayhello.delay()

return HttpResponse("hello world")

Django

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Vagrant 使用笔记
下一篇:【Unity3D日常开发】(二十七)Unity3D中快速复制场景中的对象的坐标位置,并且粘贴出来
相关文章