使用celery异步处理发送短信功能

Celery介绍:

  • 简单,易于使用和维护,有丰富的文档。
  • 高效,单个celery进程每分钟可以处理数百万个任务。
  • 灵活,celery中几乎每个部分都可以自定义扩展。

下载地址:也可从官方直接下载安装包:https://pypi.python.org/pypi/celery/

终端直接安装: pip install -u celery


任务队列是一种跨线程、跨机器工作的一种机制,celery通过消息进行通信,通常使用一个叫Broker(中间人)来协client(任务的发出者)和worker(任务的处理者). clients发出消息到队列中,broker将队列中的信息派发给worker来处理。一个celery系统可以包含很多的worker和broker,可增强横向扩展性和高可用性能。

使用celery异步处理发送短信功能_第1张图片

 

 

异步处理短信:

  1. 先创建celery_tasks子应用用于保存celery异步任务。
  2. 在celery_tasks目录下创建config.py文件,用于保存celery的配置信息
  3. broker_url = "redis://127.0.0.1/14"

    在celery_tasks目录下创建main.py文件,用于作为celery的启动文件

  4. from celery import Celery
    
    # 为celery使用django配置文件进行设置
    import os
    if not os.getenv('DJANGO_SETTINGS_MODULE'):
        os.environ['DJANGO_SETTINGS_MODULE'] = 'meiduo_mall.settings.dev'
    
    # 创建celery应用
    app = Celery('meiduo')
    
    # 导入celery配置
    app.config_from_object('celery_tasks.config')
    
    # 自动注册celery任务
    app.autodiscover_tasks(['celery_tasks.sms'])

    在celery_tasks/sms/目录下创建tasks.py文件,用于保存发送短信的异步任务

  5. import logging
    
    from celery_tasks.main import app
    from .yuntongxun.sms import CCP
    
    logger = logging.getLogger("django")
    
    # 验证码短信模板
    SMS_CODE_TEMP_ID = 1
    
    @app.task(name='send_sms_code')
    def send_sms_code(mobile, code, expires):
        """
        发送短信验证码
        :param mobile: 手机号
        :param code: 验证码
        :param expires: 有效期
        :return: None
        """
    
        try:
            ccp = CCP()
            result = ccp.send_template_sms(mobile, [code, expires], SMS_CODE_TEMP_ID)
        except Exception as e:
            logger.error("发送验证码短信[异常][ mobile: %s, message: %s ]" % (mobile, e))
        else:
            if result == 0:
                logger.info("发送验证码短信[正常][ mobile: %s ]" % mobile)
            else:
                logger.warning("发送验证码短信[失败][ mobile: %s ]" % mobile)

    在verifications/views.py中改写SMSCodeView视图,使用celery异步任务发送短信

  6. from celery_tasks.sms import tasks as sms_tasks
    
    class SMSCodeView(GenericAPIView):
        ...
            # 发送短信验证码
            sms_code_expires = str(constants.SMS_CODE_REDIS_EXPIRES // 60)
            sms_tasks.send_sms_code.delay(mobile, sms_code, sms_code_expires)
    
            return Response({"message": "OK"})

     

 

 

你可能感兴趣的:(语法知识)