python 异步任务框架 celery

简介

  celery 是一个分布式任务调度框架,由 python 编写。它专注于实时处理,在任务发布后,管理分配任务到不同的服务器,并取得结果。在执行任务分配时需要一个消息中间件(Broker),在 客户端 Worker 之间进行协调,比如:MQ/redis等。最后将任务返回的结果存储到数据库(Backend

 

Celery 使用

1、安装

使用 pip 命令安装

pip install celery

 

2、初始化

我的文件目录如下:

2.1 创建 celery_myself.py 文件,实例化 Celery 类

from celery import Celery

# celery_myself是当前模块的名称,可以省略,建议以当前模块名为名称
celery = Celery('celery_myself',
                # 选择中间件redis
                # broker='redis://sy-suz-test03:6379/0'
                # 选择中间件 rabbitmq
                broker='amqp://账号:密码@127.0.0.1:5672/tob')

# 注意这里,必须导入自定义的tasks任务到实例对象celery
# celery.conf['imports'] = ['core.tasks', ]
celery.conf.update(imports = ['core.tasks',])

2.2 创建 tasks.py 文件,定义任务函数

from core.celery_myself import celery

@celery.task
def fn(a, b):
    data = a*b
    print(f'参数{a}、{b}。计算结果{data}')
    return data

 

3、运行 worker 

 CD 到 celery_myself.py 目录下,执行以下命令:

celery -A celery_myself worker --pool=solo --loglevel=INFO

看到以下信息成功运行:

遇到一个问题,写这篇博客的时候,新建了一个虚拟环境运行demo,但运行命令时报错:ImportError: cannot import name 'Celery' from 'celery',排查了好久,我的另一个python虚拟环境是没问题的,网上也搜不到解决方法,后来google外网看到了一篇和我同样问题的帖子。原因是库 importlib-metadata 版本太高了和 celery 不兼容,将 importlib-metadata 降成 4.13.0 就OK了。

 

4、调用任务

创建 run.py 文件,调用任务函数

from core.tasks import fn

fn.delay(2,3)

通过调用任务的 delay 来执行对应的任务。celery 会把执行命令发送到 broker,然后 broker 的消息会被 worker 服务消费,如果一切正常你将会在 worker 服务的日志中看到接收任务和执行任务的日志。 

 

5、保存结果

修改 celery_myself.py 文件,增加 backend 参数,比如设置 redis 存储

from celery import Celery

# celery_myself是当前模块的名称,可以省略,建议以当前模块名为名称
celery = Celery('celery_myself',
                # 指定中间件 rabbitmq
                broker='amqp://账号:密码@127.0.0.1:5672/tob',
                # 指定存储数据库 redis
                backend='redis://127.0.0.1:6379/0')

再调用任务函数

from core.tasks import fn

res = fn.delay(2,3)
# 查看任务是否执行完成了。返回True表示执行完成,False表示未完成
print(res.ready())

查看 redis 数据,result 值为 6 。

 

6、在 Flask 框架下运用

先安装pip install flask-celery-helper,辅助处理 Celery 的初始化,运用 init_app() 方法。Flask 官方文档说是现在不需要再扩展了,但如果使用 工厂模式 创建app的时候 实例化Celery 的参数配置在app对象里的话,就得扩展使用 init_app() 来初始化参数。

 

7、celery worker 模式

celery 可以设置多种并发模式:多进程模式,每启动一个 worker 就是多开启一个进程。协程模式,使用 gevent、eventlet 启动协程,-c 开启 100 并发。

celery -A starter.celery worker --loglevel=INFO -P eventlet -c 100

 

8、pycharm 调试 celery

介绍个调试 celery 的小技巧,点击右上角 "Edit Configurations"

新增一个python配置

1、选择“Module name”(默认是Script path),填入 celery。

2、"Parameters" 填入参数 -A starter.celery worker --pool=solo --loglevel=INFO

然后点击 pycharm 的 debug 按钮,打印如下信息:

 

posted @ 2022-10-21 09:45  三只松鼠  阅读(3900)  评论(0编辑  收藏  举报