celery 简介

1.首先介绍一下celery:

Celery 是一个异步任务队列。一个Celery安装有三个核心组件:

Celery 客户端: 用于发布后台作业。当与 Flask 一起工作的时候,客户端与 Flask 应用一起运行。

Celery workers: 运行后台作业的进程。Celery 支持本地和远程的 workers,可以在 Flask 服务器上启动一个单独的 worker,也可以在远程服务器上启动worker,需要拷贝代码;

消息代理: 客户端通过消息队列和 workers 进行通信,Celery 支持多种方式来实现这些队列。最常用的代理就是 RabbitMQ 和 Redis。

Redis 配置

一定要关闭保护模式,避免不必要的麻烦

详细配置和介绍请看这里:

# 关闭保护模式
protected-mode "no"  
# 监听IP:默认为 127.0.0.1
# 如果需要远程访问,可将此⾏注释,或绑定⼀个真实IP
#  bind 127.0.0.1 注销掉 设置为其它主机都可以连接
# 监听端⼝:默认为 6379 
port 6379
# 是否以守护进程运⾏,默认为 yes
daemonize yes
# Redis 中数据持久化保存时的文件
dbfilename dump.rdb
# dump.rdb 文件所在的目录
dir /var/lib/redis
# Redis 输出⽇志⽂件路径
logfile /var/log/redis/redis-server.log
# Redis 中的数据库数量,默认为 16,编号为:0-15
databases 16

2. 生产者和消费者设计模式

最常用的解耦方式之一,是寻找 中间人(broker) 搭桥,保证两个业务没有直接关联,我们称这一解耦方式为:生产者消费者设计模式。

celery支持redis集群 celery绑定redis集群_python

生产者消费者设计模式的具体执行流程如下:

生产者一方发出任务消息(通知),任务消息存入消息队列,生产者继续做自己的事情
消费者一方监听消息队列,取出对应的任务消息(通知),根据消息去执行对应的任务
短信验证码发送的异步解决方案:

celery支持redis集群 celery绑定redis集群_Redis_02

短信发送API一方(生产者)发出发送短信的任务消息,任务消息存入消息队列,然后短信发送API给客户端返回响应
短发发送工作者一方(消费者)监听消息队列,取出对应的任务消息,根据消息进行短信验证码的实际发送

3. Celery-分布式消息队列系统

Celery是一个简单、灵活的分布式消息队列系统,使用python语言开发。Celery的本质就是生产者-消费者设计模式,使用Celery可以非常方便的实现异步任务的执行。

3.1 Celery核心三要素

核心要素 作用说明
client 生产者,发出任务消息,存储到broker
broker 中间人,消息队列,存储任务消息,官方推荐使用rabbit-mq或redis
worker 消费者,任务执行者,根据任务消息执行对应的任务

3.2 Celery基本使用

环境安装:

1)进入自己的虚拟环境,安装Celery包和eventlet(win10环境下)
window10需要插件eventlet

pip install celery==4.4.7
pip install eventlet

代码编写:

1)随便位置创建一个目录 celery_tasks,并在这个目录下创建一个 main.py 文件和一个 config.py 文件(创建文件可以使用pycharm 或者自己直接创建)

mkdir celery_tasks
touch main.py config.py

celery支持redis集群 celery绑定redis集群_redis_03

2)编辑 config.py 文件,在其中添加配置项,指定Celery broker 的地址,代码如下:

# 指定broker中间人(消息队列)地址,本示例使用redis作为broker
# 格式:broker_url='redis://<redis-ip>:<redis-port>/<db>'
# 注意:将192.168.19.131改成自己的redis数据库ip,并且redis数据库一定要启动!!!
broker_url='redis://192.168.19.131:6379/3'

3)编辑 main.py 文件,在启动创建 Celery 对象,并加载 config.py 中的配置

from celery import Celery

# ①  创建Celery对象
celery_app = Celery('demo')

# ②  加载config.py的配置
celery_app.config_from_object('celery_tasks.config')

4)在 celery_tasks 目录下,创建一个任务目录 sms,同时在 sms 目录下创建一个任务文件 tasks.py

mkdir sms

touch init.py tasks.py

celery支持redis集群 celery绑定redis集群_celery支持redis集群_04

5)编辑 sms/tasks.py,在其中添加一个任务函数

# 导入Celery对象
from celery_tasks.main import celery_app
# @celery_app.task("任务名称")
@celery_app.task(name = "send_sms_code")
def send_sms_code(mobile, sms_code):
    """封装任务函数代码"""
    print("发送短信任务函数代码...")

6)回去编辑 main.py 文件,设置celery worker启动时自动加载 sms/tasks.py 中的任务函数

from celery import Celery
# ①  创建Celery对象
celery_app = Celery('demo')

# ②  加载config.py的配置
celery_app.config_from_object('celery_tasks.config')

# ③  celery worker启动时自动加载任务
celery_app.autodiscover_tasks(['celery_tasks.sms'])
worker启动:

1)上面代码编写完成之后,我们可以对celery进行测试,首先需要启动celery的 worker,命令如下:

# 注意:
# ① 确保自己提取进入了安装celery的虚拟环境
# ② 下面的worker启动命令,一定要在 celery_tasks目录 的上级执行!!!
celery -A celery_tasks.main worker -l info -P eventlet
# 如果出现warning -n [option] 无需理会
2)celery worker 启动之后,提示信息如下:

celery支持redis集群 celery绑定redis集群_消息队列_05

任务消息发出:

celery worker 启动之后,client可以向 broker 中发出任务消息,celery worker 收到任务消息之后,就会执行对应的任务函数。下面我们来演示通知 celery worker 执行 send_sms_code 任务函数:

1)在虚拟机环境中进入 celery_tasks 的上级目录,进入python交互终端,执行如下操作:

python
>>> from celery_tasks.sms.tasks import send_sms_code
>>> send_sms_code.delay('13566667788', '135268')

2)执行效果如下:

celery支持redis集群 celery绑定redis集群_redis_06