美多商城用户注册-展示用户注册页面-短信验证码异步方案Celery-8
生产者消费者设计模式
生产设消费者设计模式介绍
Celery介绍使用:
Celery介绍:
一个简单、灵活且可靠、处理大量消息的分布式系统,可以在一台或者多台机器上运行。
单个 Celery 进程每分钟可处理数以百万计的任务。
通过消息进行通信,使用消息队列(broker)在客户端和消费者之间进行协调。
安装Celery 在pycharm中安装
创建Celery实例并加载配置,在项目中创建celery_tasks软件包,并创建main.py文件
main文件内容如下
# celery启动文件
from celery import Celery
# 创建celery实例
celery_app = Celery('meiduo')
加载celery需要配置一个config.py文件 来绑定消息队列位置
broker_url = 'redis://IP/10'
在main文件中添加加载配置、注册配置代码
# 加载celery配置
celery_app.config_from_object('celery_tasks.config')
# 自动注册celery任务
celery_app.autodiscover_tasks(['celery_tasks.sms'])
定义任务需要在celery_tasks中创建sms软件包把原有的发送短信的代码拷贝到这里
constants也需要拷贝一份 并创建tasks.py文件
创建
tasks.py文件如下
#定义任务
from celery_tasks.main import celery_app
from celery_tasks.sms.constants import SMS_CODE_REDIS_EXPIRES
from celery_tasks.sms.huyi.ccp_sms import send_sms
# 使用装饰器异步任务,保证celery识别任务
@celery_app.task(name='send_sms_code')
def send_sms_code(mobile):
"""发送短信验证码异步的任务"""
sms_code = str(send_sms(mobile, [SMS_CODE_REDIS_EXPIRES // 60]))
return sms_code
并且在 verifications中的views中 添加如下
send_sms_code.delay(mobile) #千万不要忘记写delay
然后在pycharm中的控制台中,celery_tasks中执行
celery -A celery_tasks.main worker -l info