Celery异步任务
Celery异步任务
(1)安装celery
pip install celery==4.2.1
(2)celery使用
在项目适当位置创建celery_tasks目录用于保存celery异步任务。
在celery_tasks目录下创建config.py文件,用于保存celery的配置信息,配置内容如下:
broker_url = "redis://127.0.0.1/14" # 这里使用的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') # meiduo为应用名,可以修改
# 导入celery配置
app.config_from_object('celery_tasks.config')
# 自动注册celery任务
app.autodiscover_tasks(['celery_tasks.sms']) # 此处可以添加多个任务
这里举一个celery异步发短信的例子:
在celery_tasks目录下创建sms目录,用于放置发送短信的异步任务相关代码
在celery_tasks/sms/目录下创建send_messages.py文件,定义发短信的函数,内容如下:
import requests
# 接口地址
url = 'http://106.ihuyi.com/webservice/sms.php?method=Submit'
# 这里使用的是互亿无线的短信服务,不同的短信服务,api是不相同的,根据接口文档进行编写
def send_message(code, mobile):
# 定义请求的数据
values = {
'account': 'C7*******', # 自己的短信平台账号
'password': '7ff8*************', # 短信平台账号密码
'mobile': mobile, # 目标号码
'content': '您的验证码是:' + code + '。请不要把验证码泄露给其他人。', # 短信内容
'format': 'json',
}
requests.get(url, params=values)
在celery_tasks/sms/目录下创建tasks.py文件,用于保存发送短信的异步任务,该文件必须是tasks.py,不能是别的名字
import logging
from celery_tasks.main import app
from celery_tasks.sms.send_messages import send_message
logger = logging.getLogger("django")
@app.task(name='send_sms_code')
def send_sms_code(sms_code, mobile):
"""
发送短信验证码
:param mobile: 手机号
:param sms_code: 验证码
:return: None
"""
try:
send_message(sms_code, mobile)
except Exception as e:
logger.error("发送验证码短信[异常][ mobile: %s, message: %s ]" % (mobile, e))
调用异步任务,使用celery异步任务发送短信
from celery_tasks.sms.tasks import send_sms_code
# 利用互亿无线发短信
send_sms_code.delay("457624", 10086)
(3) 启动celery
首先进入到celery_tasks所在的同级目录
celery -A celery_tasks.main worker -l info --pool=solo