异步方案celery

官方文档

生产者消费者设计模式

生产者生成消息,缓存到消息队列中,消费者读取消息队列中的消息并执行,

  • Celery介绍
    • 一个简单、灵活且可靠、处理大量消息的分布式系统,可以在一台或者多台机器上运行。
    • 单个 Celery 进程每分钟可处理数以百万计的任务。
    • 通过消息进行通信,使用消息队列( broker )在客户端和消费者之间进行协调。

创建 Celery 实例并加载配置

1.定义 Celery 包

  • 包里有两个文件main.py和config.py

2.main.py

# 导入 Celery 类
from celery import Celery

# 创建 celery 实例
# 需要添加一个参数,是个字符串, 内容随意添加
celery_app = Celery('meiduo')

# 给 celery 添加配置
# 里面的参数为我们创建的 config 配置文件:
celery_app.config_from_object('celery_tasks.config')

3.config.py

# 添加消息队列的地址
broker_url = 'redis://127.0.0.1:6379/3'

4.定义任务

  • 建个包,再新建task.py
# bind:保证task对象会作为第一个参数自动传入
# name:异步任务别名
# retry_backoff:异常自动重试的时间间隔 第n次(retry_backoff×2^(n-1))s
# max_retries:异常自动重试次数的上限
@celery_app.task(bind=True, name='ccp_send_sms_code', retry_backoff=3)
def ccp_send_sms_code(self, mobile, sms_code):
    """
    发送短信异步任务
    :param mobile: 手机号
    :param sms_code: 短信验证码
    :return: 成功0 或 失败-1
    """

    try:
        # 调用 CCP() 发送短信, 并传递相关参数: 
        result = CCP().send_template_sms(mobile, 
                                         [sms_code, 5], 
                                         1)

    except Exception as e:
        # 如果发送过程出错, 打印错误日志
        logger.error(e)

        # 有异常自动重试三次
        raise self.retry(exc=e, max_retries=3)

       # 如果发送成功, rend_ret 为 0: 
    if result != 0:
        # 有异常自动重试三次
        raise self.retry(exc=Exception('发送短信失败'), max_retries=3)

    return result

5.启动Celery服务

  • 在能看到Celery包的路径下,调用下面的命令行:
    ·celery -A celery_tasks.main worker -l info·

6.调用发送短信的任务

# Celery 异步发送短信验证码
ccp_send_sms_code.delay(mobile, sms_code)

更改celery工作模式

  • 默认是进程的方式,一个cpu默认开四个进程
  • 改为协程
  1. pip install eventlet
posted @ 2019-07-17 20:59  太虚真人  阅读(398)  评论(1编辑  收藏  举报