美多商城用户注册-展示用户注册页面-短信验证码异步方案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

 

posted @ 2024-01-19 16:02  疯狂的米粒儿  阅读(5)  评论(0编辑  收藏  举报