zoukankan      html  css  js  c++  java
  • Celery 实现异步任务-one

    celery异步任务:

    环境准备

    安装celery ,django-celery.

    就是一个专注于实时处理和任务调度的分布式队列。

    可以异步执行的任务交给后台处理,以防网络阻塞,减小响应时间 celery使用:

    1. 在工程目录下创建一个celery_tasks文件包用于保存celery异步任务。

    2. 在celery_tasks目录下创建config.py文件,用于保存celery的配置信息,储存在redis数据库中。

        broker_url = "redis://127.0.0.1/14"

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

        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

      import djcelery
         djcelery.setup_loader()
         #末尾添加
         CELERYBEAT_SCHEDULER = ‘djcelery.schedulers.DatabaseScheduler‘  # 这是使用了django-celery默认的数据库调度模型,任务执行周期都被存在你指定的orm数据库中
         
         #INstalled_apps
             INSTALLED_APPS = (
            ‘django.contrib.admin‘,
            ‘django.contrib.auth‘,
            ‘django.contrib.contenttypes‘,
            ‘django.contrib.sessions‘,
            ‘django.contrib.messages‘,
            ‘django.contrib.staticfiles‘,
            ‘djcelery‘,    #### 这里增加了djcelery 也就是为了在        django admin里面可一直接配置和查看celery
            ‘blog‘,     ###
        )
       

    举例:发送短信

    在celery_tasks目录下创建sms目录,用于放置发送短信的异步任务相关代码。

    将提供的发送短信的云通讯SDK放到celery_tasks/sms/目录下。

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

      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异步任务发送短信.

        
     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"})

     

  • 相关阅读:
    话说Hibernate和ADO.NET —练习随笔小记
    二次开发WinWebMail邮件系统接口 企业邮件服务器解决方案
    一个Windows后台服务(.Net的C#版) 定时访问数据库循环发送手机短信
    SQL UPDATE 联合表更新的问题
    2009新的篇章,惠海→时代财富→广佛都市网
    在WebService中使用Session或Cookie实现WebService身份验证(客户端是Flex)
    门户网站的形成—CMS内容管理系统
    CSS实现0.5px的边框或线
    《后人诗》
    CentOS6下docker的安装和使用
  • 原文地址:https://www.cnblogs.com/xiaozengzeng/p/10702643.html
Copyright © 2011-2022 走看看