Django框架在使用celery 和 Redis 时发生冲突的解决

Celery简介
情景:用户发起request,并等待response返回。在本些views中,可能需要执行一段耗时的程序,那么用户就会等待很长时间,造成不好的用户体验,比如发送邮件、手机验证码等。

使用celery后,情况就不一样了。解决:将耗时的程序放到celery中执行。
我们在做网站后端程序开发时,会碰到这样的需求:用户需要在我们的网站填写注册信息,我们发给用户一封注册激活邮件到用户邮箱,如果由于各种原因,这封邮件发送所需时间较长,那么客户端将会等待很久,造成不好的用户体验.

所以我们将耗时任务放到后台异步执行。不会影响用户其他操作。 我们可使用celery实现异步执行任务.
celery简单的工作原理:
celery通过消息进行通信,通常使用一个叫Broker(中间人)来协client(任务的发出者)和worker(任务的处理者). clients发出消息到队列中,broker将队列中的信息派发给worker来处理。

一个celery系统可以包含很多的worker和broker,可增强横向扩展性和高可用性能。
在这里插入图片描述
在Django1.8.2的版本下,需要使用如下安装方式:
pip install celery==3.1.25

pip install django-celery==3.1.17

使用方法: task.py

from celery import Celery
from django.conf import settings
from django.core.mail import send_mail
app = Celery(‘celery_tasks.tasks’, broker = ‘redis://127.0.0.1:6379/8’)#将应用注册
import os
import django
os.environ.setdefault(“DJANGO_SETTINGS_MODULE”, “daliyfresh.settings”)
django.setup()
#初始化Django的配置
@app.task
def send_active_email(to_email, username, token):
subject = ‘你发送邮件的标题’
message = ‘’
sender = settings.EMAIL_FROM
receiver = [to_email]
html_message = ‘你需要发送的信息’
send_mail(subject, message, sender, receiver, html_message=html_message)
#此处发送邮件使用的为Django内置方法,需要自行再去setting配置一下自己所需要的参数

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值