celery分布式搭配django操作文档

1.pip install django-redis==5.0.0#下载django版本的redis,pip install celery

2.在settings.py文件配置缓存(redis)的相关配置

3.在项目同名文件夹下创建一个celery.py文件,配置内容如下:

'''
本文件用来celery配置文件
'''
from celery import Celery
from django.conf import settings
import os
# 为celery设置环境变量
os.environ.setdefault('DJANGO_SETTINGS_MODULE', '<同名文件夹>.settings')
CELERY_BROKER_URL = 'redis://:@127.0.0.1:6379/0' # Broker配置,使用Redis0库作为消息中间件
CELERY_RESULT_BACKEND = 'redis://:@127.0.0.1:6379/0' # BACKEND配置,这里使用redis0库
# 创建应用
app = Celery('<同名文件夹>',broker=CELERY_BROKER_URL,backend=CELERY_RESULT_BACKEND)
# 设置app自动加载任务,从已经安装的app中查找任务
app.autodiscover_tasks(settings.INSTALLED_APPS)

4.在同名文件夹下的__init__.py中,配置内容如下:

from __future__ import absolute_import, unicode_literals
from .celery import app as celery_app
__all__ = ['celery_app']

5.在创建的应用文件夹下,创建一个tasks.py文件,其中配置如下:

from <项目同名文件夹>.celery import app
@app.task#装饰器
def function(参数):#自定义函数
	return

6.在需要的视图文件views.py中引入tasks.function函数,即可完成调用(值得注意的是,此处调用得按照celery的调用方式,如:function.delay(参数),无法直接调用如:function())

7.进入到项目下,启动celery指令:celery -A <项目名> worker -l info(值得注意的是,此操作之前,一定得将redis服务启动,如:redis-server)
如果过程中出现ValueError: not enough values to unpack (expected 3, got 0),
解决方法如下:
7.1先安装一个eventlet(pip install eventlet)
7.2启动celery指令:celery -A <项目名> worker -l info -P eventlet(多了个参数-P eventlet)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值