flask爱家租房项目开发(九)

本文代码下载地址:https://download.csdn.net/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

如果启动成功

flask爱家租房项目开发(九)_第1张图片

刷新浏览器,注册一个账号

flask爱家租房项目开发(九)_第2张图片

 

celery目录结构使用

当有多个任务的时候不肯能都放到一个文件中

而celery本身就是一个独立的程序

可以创建一个任务的工程,进行相应的配置

flask爱家租房项目开发(九)_第3张图片

# 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

flask爱家租房项目开发(九)_第4张图片

flask爱家租房项目开发(九)_第5张图片

celery独立目录

接收返回值,return

# 定义任务
@celery_app.task
def send_sms(to, datas, temp_id):
    """发送短信的异步任务"""
    ccp = CCP()
    return ccp.sendTemplateSMS(to, datas, temp_id)

 

 

 

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(python3)