Django笔记--使用celery异步完成发送验证码的步骤

目的: 将耗时的代码放入一个新的进程中执行
解决方法: 使用celery

 

1.在虚拟环境中安装包celery

pip install celery

2.在项目目录下新建celery_tasks包

3.在celery_tasks下新建config.py===>指定broker到redis

# config.py

 broker_url='redis://127.0.0.1:6379/14'

4.在celery_tasks下新建main.py===>app = Celery()

from celery import Celery

# 为celery使用django配置文件进行设置
import os
if not os.getenv('DJANGO_SETTINGS_MODULE'):
    os.environ['DJANGO_SETTINGS_MODULE'] = '项目名.settings'

# 创建celery应用
app = Celery('xxx')

# 导入celery配置
app.config_from_object('celery_tasks.config')

# 自动注册celery任务
app.autodiscover_tasks(['celery_tasks.功能包名'])

5.在celery_tasks下新建任务包(如sms),创建tasks.py

 

6.在tasks.py中定义函数:加装饰器@app.task(name="")

import logging
from celery_tasks.main import app
from utils.ytx_sdk.sendSMS import CCP
logger = logging.getLogger("django")

@app.task(name='send_sms_code')
def send_sms_code(mobile, code, expires, template_id):
    """
        发送短信验证码
        :param mobile: 手机号
        :param code: 验证码
        :param expires: 有效期
        :param template_id:发送短信的模板id
        """

    try:
        # result = CCP.send_template_sms(mobile, [code, expires], template_id)
        result = 0
        print(code)
    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)

7.在views.py中使用celery====>任务函数.delay(参数)

 send_sms_code.delay(mobile,sms_code,sms_code_expires,1)

8.在项目目录下启动工人worker

celery -A celery_tasks.main worker -l info

 

如果你和我有共同爱好,我们可以加个好友一起交流!

 

你可能感兴趣的:(Django框架系列,celery异步,django)