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

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

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

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

一个celery系统可以包含很多的worker和broker,可增强横向扩展性和高可用性能。
Django框架在使用celery 和 Redis 时发生冲突的解决_第1张图片
在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配置一下自己所需要的参数

你可能感兴趣的:(Django框架在使用celery 和 Redis 时发生冲突的解决)