celery工作方式:
使用celery第一件要做的最为重要的事情是需要先创建一个Celery实例,我们一般叫做celery应用,或者更简单直接叫做一个app。app应用是我们使用celery所有功能的入口,比如创建任务,管理任务等,在使用celery的时候,app必须能够被其他的模块导入。
配置celery
创建项目celery_tasks文件夹:
在celery_tasks中创建一个man.py作为启动模块
from celery import Celery
# 为celery使用django配置文件进行设置
import os
if not os.getenv('DJANGO_SETTINGS_MODULE'):
os.environ['DJANGO_SETTINGS_MODULE'] = '项目名.settings.dev' # 找到项目的配置文件的路径
# 创建celery应用
celery_app = Celery('demo') # 应用名字为demo
# 导入celery配置
celery_app.config_from_object('celery_tasks.config')
# 导入任务
celery_app.autodiscover_tasks(['celery_tasks.sms', 'celery_tasks.email', 'celery_tasks.html']) # 目的是找到sms中定义的tasks的任务
再创建config.py定义中间人redis的配置
broker_url = "redis://10.211.55.5/14"
创建应用文件夹sms实现发送短信的相关业务:
在sms文件夹中创建tasks.py文件(注意必须是tasks.py文件)实现具体的代码
tasks.py中代码如下:
from .utils.yuntongxun.sms import CCP
import logging
from celery_tasks.main import celery_app # 导入实现逻辑相应所需的包
logger = logging.getLogger('django')
@celery_app.task(name='send_sms_code')
def send_sms_code(mobile, sms_code, expires, temp_id):
"""发送短信验证码"""
try:
ccp = CCP()
result = ccp.send_template_sms(mobile, [sms_code, expires], 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)
至此celery的配置就算完了
在具体的视图业务中就可以直接使用:
# 使用celery发送短信验证码
expires = constants.SMS_CODE_REDIS_EXPIRES // 60
send_sms_code.delay(mobile, sms_code, expires, constants.SMS_CODE_TEMP_ID)
return Response({'message': 'OK'})