本文代码下载地址:https://download.youkuaiyun.com/download/geek_xiong/11571870
celery的基本使用
先以发送短信为例
安装celery和eventlet
pip install celery
pip install eventlet
定义一个发送短信的任务
# tasks_tasks_sms.py
from celery import Celery
from ihome.libs.yuntongxun.sms import CCP
# 定义celery对象
celery_app = Celery("ihome", broker="redis://127.0.0.1:6379/1")
# 定义任务
@celery_app.task
def send_sms(to, datas, temp_id):
"""发送短信的异步任务"""
ccp = CCP()
ccp.sendTemplateSMS(to, datas, temp_id)
在需要发送短信的地方调用这个任务,使其异步执行
# verify_code.py
from ihome.tasks.tasks_sms import send_sms
# 发送短信验证码
send_sms.delay(mobile, [sms_code, int(constants.SMS_CODE_REDIS_EXPIRES/60)], 1)
# 返回结果
return jsonify(errno=RET.OK, errmsg='发送成功')
启动项目
python manage.py runserver
启动worker任务
在同目录下开启另一个终端,启动worker
celery -A ihome.tasks.main worker -l info -P eventlet
如果启动成功
刷新浏览器,注册一个账号
celery目录结构使用
当有多个任务的时候不肯能都放到一个文件中
而celery本身就是一个独立的程序
可以创建一个任务的工程,进行相应的配置
# config.py
BROKER_URL = "redis://127.0.0.1:6379/1"
CELERY_RESULT_BACKEND = "redis://127.0.0.1:6379/2"
# main.py
from celery import Celery
from ihome.tasks import config
# 定义celery对象
celery_app = Celery("ihome")
# 引入配置信息
celery_app.config_from_object(config)
# 自动搜索异步任务
celery_app.autodiscover_tasks(['ihome.tasks.sms'])
# sms/tasks.py
from ihome.tasks.main import celery_app
from ihome.libs.yuntongxun.sms import CCP
# 定义任务
@celery_app.task
def send_sms(to, datas, temp_id):
"""发送短信的异步任务"""
ccp = CCP()
ccp.sendTemplateSMS(to, datas, temp_id)
修改发送短信任务的引入路径
# verify_code.py
from ihome.tasks.sms.tasks import send_sms
启动worker
celery -A ihome.tasks.main worker -l info -P eventlet
celery独立目录
略
接收返回值,return
# 定义任务
@celery_app.task
def send_sms(to, datas, temp_id):
"""发送短信的异步任务"""
ccp = CCP()
return ccp.sendTemplateSMS(to, datas, temp_id)