celery异步发送邮箱
python3.7版本
使用django内置的函数发送邮件时,django给stmp服务器发送邮件需要时间,stmp服务器发送邮件给用户也需要时间,而在发送邮件这段时间内,用户是在等服务端返回应答的,如果等待时间过长,那么无疑会大大的降低用户的体验。
这个时候,我们可以使用celery来异步发送邮件,即Django服务端在celery发送邮件的同时,返回应答给用户。这里,我们使用sleep来模拟发送邮件的时常。
一. 打开163邮箱,打开设置点击POP3/SMTP/IMAP
二. 打开POP3/SMTP服务(注意,这时会自动生成一个客户端授权密码,只会显示一次,需要记下来)
三. Django配置文件(settings.py)中配置
# 邮件设置
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.163.com'
EMAIL_PORT = 25
# 发送邮件的邮箱
EMAIL_HOST_USER = 'xxxx@163.com'
# 在邮箱中设置的客户端授权密码
EMAIL_HOST_PASSWORD = '这里是生成的授权码'
# 收件人看到的发件人
EMAIL_FROM = 'mff<xxx@163.com>'
# diango的缓存配置
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/8",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
四. 安装celery(这里需要注意和我的安装版本一致)
pip install celery==4.2.1 -i https://pypi.tuna.tsinghua.edu.cn/simple
五. 在项目下新建celery_tasks文件夹,在文件夹中新建tasks.py文件,编写tasks文件;
from django.core.mail import send_mail
from django.conf import settings
from celery import Celery
import time
# 在任务处理者一端时需要加这几句,关于这里请看后面开启redis服务后的代码拷贝,这里保持注释状态即可
import os
import django
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "项目名.settings")
django.setup()
# 创建一个Celery类的实例对象
app = Celery('celery_tasks.tasks', broker='redis://127.0.0.1:6379/8')
# 定义任务函数
@app.task
def send_register_active_email(to_email, username):
"""发送激活邮件"""
subject = "mff欢迎信息"
message = ""
sender = settings.EMAIL_FROM
receiver = [to_email]
html_message = "<h2>%s, 欢迎你成为mff注册会员</h2>" % (username)
send_mail(subject, message, sender, receiver, html_message=html_message)
time.sleep(5)
六. 在发送邮件的地方调用celery_tasks下的tasks下的发送邮件函数;
from celery_tasks.tasks import *
def emailtest(request):
username = "mumun"
# 需要发送到谁的邮箱
email = ""
# 使用celery发送邮件
send_register_active_email.delay(email, username)
# 返回应答,跳转到首页
return "邮件发送成功,请注意接收"
七. 配套url
from views import emailtest
urlpatterns = [
url(r'^emailtest/$', views.emailtest, name="emailtest"), # 发邮件测试
]
八. 开启redis服务
redis-server
redis-cli
select 8
keys *
九. 开启worker模式:
1. cd 到项目内
2. Linux/mac 系统运行 celery -A celery_tasks.tasks worker -l info
3. win10系统需要安装eventlet(需要版本一致)
pip install eventlet==0.26.0 -i https://pypi.tuna.tsinghua.edu.cn/simple
- 安装完成后运行
celery -A celery_tasks.tasks worker -l info -P eventlet
如上图即为成功,这时候就可以发送邮件了
gitee path: https://gitee.com/mff-project
bolg path:https://mff-project.gitee.io/blog
weibo path:https://weibo.com/myismff/