21、celery 完成耗时功能和定时任务

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就完成了异步任务。

可以按照这种方式改写到项目的发邮件功能,使用异步实现发邮件,快速响应,提高用户的体验度。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值