介绍
Celery是一个功能完备即插即用的任务队列。它使得我们不需要考虑复杂的问题,使用非常简单。celery看起来似乎很庞大,本章节我们先对其进行简单的了解,然后再去学习其他一些高级特性。 celery适用异步处理问题,当发送邮件、或者文件上传, 图像处理等等一些比较耗时的操作,我们可将其异步执行,这样用户不需要等待很久,提高用户体验。 celery的特点是:
- 简单,易于使用和维护,有丰富的文档。
- 高效,单个celery进程每分钟可以处理数百万个任务。
- 灵活,celery中几乎每个部分都可以自定义扩展。
安装celery
这个和版本有关,可能会报错。我使用的django版是1.8.1, celery版本就不能安装4.0以上的。我安装是3.8.2
使用
from celery import Celery
app = Celery('celery_tasks.tasks', broker='redis://127.0.0.1:6379/1')
# 定义任务函数
@app.task
def send_register_active_email(to_email, username, token):
"""发送激活"""
subject = "欢迎信息"
message = ""
sender = settings.EMAIL_FROM
receiver = [to_email]
html_message = '<h1>%s, 欢迎您成为注册会员</h1>请点击下面链接激活您的账户<br/><a href="http://127.0.0.1:8000/user/active/%s">http://127.0.0.1:8000/user/active/%s</a>' % (
username, token, token)
send_mail(subject, message, sender, receiver, html_message=html_message)
time.sleep(10)
然后在视图中导入这个文件进行使用
from celery_tasks.tasks import send_register_active_email
email = []
username = []
token = 'xxxxxx'
send_register_active_email.delay(email, username, token)
注意delay方法,一定要写上,不要忘记写,否则不能异步执行成功
在redis端 进入项目目录执行命令监听
celery -A celery_tasks.tasks worker -l info
出来上面的代码就说明服务端在监听这个任务队列了。