celery
官网网站:
https://pypi.org/project/celery/
参考网站:
https://blog.csdn.net/cuomer/article/details/81214438
https://www.cnblogs.com/crb912/p/8976937.html
celery(芹菜)是一个简单、灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必需工具。
分布式:就是将任务分发个多个客户端进行处理的模式。
分布式开发,一定涉及一个设计模式:生产消费者模式。
celery支持的任务队列/中间人有三种:RabbitMQ, Redis, Amazon SQS,这是使用redis为例。
celery一般在项目可以帮我完成两个功能:
1、将耗时的功能交给celery执行,比如发邮件就是一个耗时的功能
2、定时器功能可以交给celery执行,比如电商中中午12点开始秒杀,在11:50发邮件或者发短信提示用户赶紧去登录。
这里主要演示第1个功能,celery与在django中实现异步任务。
定时器可以通过官网和参考网址自主实现。
完成步骤
1、启动redis服务器
redis-server.exe --service-start
2、安装包
记得进入自己的虚拟环境
这里需要分别安装4个包
pip install redis==2.10.6
pip install django-redis
pip install django-celery
pip install flower
注意:这里需要指定redis的包,否则默认安装最新的,导致版本过高,在后续使用会报错。经过测试redis==2.10.6是可使用的。
也可以一次性安装
pip install redis==2.10.6 django-redis django-celery flower
3、配置settings.py
4、迁移
5、新建一个包my_celery
6、在包下新建一个tasks.py文件,定义一个任务函数
7、在django中完成注册的跳转
路由:
视图:
模板:
访问:
8、启动celery
1、再次修改tasks.py文件,加载django的环境,否则下面的第2步报错
2、打开一个新的cmd窗口,进入项目所在的文件夹,进入虚拟环境,启动celery。
celery -A my_celery.tasks worker -l info
3、回到注册页面单击注册按钮,添加任务
查看控制台,并未打印任务内容,说明这时候task_send_email没有在web后端调用。
4、回到celery的cmd界面
发现任务已经完成了,那么这样使用celery就完成了异步任务。
可以按照这种方式改写到项目的发邮件功能,使用异步实现发邮件,快速响应,提高用户的体验度。