记一次django中使用celery+redis配置及问题处理

包的版本
  • pip3 install celery
  • pip3 install django-celery
  • pip3 install redis==2.10.6
启动命令
# linux / mac下
celery -A 项目名 worker -l info --beat
# windows下
celery -A 项目名 worker -l info -P eventle
主应用目录下

setting.py

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'djcelery', # 添加celery应用
]
# celery config
# 消息中间件(使用redis),消息代理,用于发布者传递消息给消费者
BROKER_URL = 'redis://127.0.0.1:6379/1'
# 消息结果返回中间件(使用redis),用于存储任务执行结果
CELERY_RESULT_BACKEND = 'redis://127.0.0.1:6379/2'
# 允许的内容类型,
CELERY_ACCEPT_CONTENT = ['json']
# 任务的序列化方式
CELERY_TASK_SERIALIZER = 'json'
# 任务结果的序列化方式
CELERY_RESULT_SERIALIZER = 'json'

__init__.py

from __future__ import absolute_import
from .celery import app as celery_app

celery.py

from __future__ import absolute_import, unicode_literals
import os
from django.conf import settings
from celery import Celery

# 设置 Django 的配置文件
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'roamsaverb2b.settings')

# 创建 celery 实例
app = Celery('test1')

# Using a string here means the worker will not have to
# pickle the object when using Windows.
app.config_from_object('django.conf:settings')

# 搜索所有 app 中的 tasks
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)


@app.task(bind=True)
def debug_task(self):
    print('Request: {0!r}'.format(self.request))

子应用目录下

tasks.py

# -*- coding:utf-8 -*-
from __future__ import absolute_import

import time

from roamsaverb2b.celery import app


@app.task
def add(x, y):
    time.sleep(30)
    print("running...", x, y)
    return x + y


# 状态有这几种情况
CELERY_STATUS = {
    'PENDING': '执行中',
    'STARTED': '任务开始',
    'SUCCESS': '成功',
    'FAILURE': '失败',
    'RETRY': '重试',
    'REVOKED': '任务取消',
}

if __name__ == '__main__':
    status = app.AsyncResult('任务id').status
    result = app.AsyncResult('任务id').result
    print(status)
    print(result)

views.py

class IndexPage(View):

    def get(self, request):
        res = add.delay(1,2)
        print(res.id) # 打印任务id,可记录到日志,方便管理
        return render(request, 'index.html')
注意事项
  • redis版本不能过高,过高会导致celery启动报错
  • windows下使用celery需安装pip install eventlet
  • 还有启动错误情况是因为redis需要修改配置文件config set stop-writes-on-bgsave-error no
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值