当前位置: 首页 > news >正文

Python-Celery-基础用法总结-安装-配置-启动

文章目录

  • 1.安装 Celery
  • 2.配置 Celery
  • 3.启动 Worker
  • 4.调用任务
  • 5.任务装饰器选项
  • 6.任务状态
  • 7.定期任务
  • 8.高级特性
  • 9.监控和管理

Celery 是一个基于分布式消息传递的异步任务队列。它专注于实时操作,但也支持调度。Celery 可以与 Django, Flask, Pyramid 等 Web 框架集成,但也可以独立使用。

1.安装 Celery

首先需要安装 Celery 和一个消息代理(如 RabbitMQ 或 Redis)。这里以 Redis 为例:

pip install celery[redis]

2.配置 Celery

创建一个 celery.py 文件来配置 Celery 应用程序:

from celery import Celeryapp = Celery('tasks', broker='redis://localhost:6379/0')@app.task
def add(x, y):return x + y
  • broker 参数指定了消息代理的 URL。
  • add 是一个简单的任务函数,它接受两个参数并返回它们的和。

3.启动 Worker

在命令行中启动一个 Celery worker,这将监听任务请求:

celery -A tasks worker --loglevel=info
  • -A 参数指定了包含 Celery 实例的模块。
  • worker 命令启动了一个工作进程。
  • --loglevel=info 设置了日志级别。

4.调用任务

可以在其他 Python 脚本中调用任务:

from tasks import addresult = add.delay(4, 4)
print(result.get())  # 输出: 8
  • delay() 方法异步执行任务。
  • get() 方法阻塞等待直到任务完成,并返回结果。

5.任务装饰器选项

可以为任务设置各种选项,例如重试策略、超时等:

@app.task(bind=True, max_retries=3)
def retry_task(self, x, y):try:return x / yexcept ZeroDivisionError as exc:raise self.retry(exc=exc, countdown=5)  # 5秒后重试
  • bind=True 让任务函数接收 self 参数,即任务本身的实例。
  • max_retries 设置最大重试次数。
  • retry() 方法用于手动重试任务。

6.任务状态

可以跟踪任务的状态和结果:

result = add.delay(10, 20)
print(result.ready())  # 返回任务是否已完成
print(result.successful())  # 返回任务是否成功完成
print(result.result)  # 返回任务的结果

7.定期任务

可以通过 Celery Beat 来调度定期任务。首先需要定义定期任务:

from celery.schedules import crontabapp.conf.beat_schedule = {'add-every-30-seconds': {'task': 'tasks.add','schedule': 30.0,'args': (16, 16)},
}

然后启动 Celery Beat 服务:

celery -A tasks beat --loglevel=info

8.高级特性

  • 链式任务:可以将多个任务链接起来,前一个任务的输出作为下一个任务的输入。
  • 组任务:同时执行多个任务,等待所有任务完成后收集结果。
  • 子任务:可以将任务嵌套到其他任务中。
  • 路由:可以将不同类型的任务发送到不同的队列。

9.监控和管理

  • Flower:是一个实时的 Celery Web 监控工具,可以查看任务状态、工作节点信息等。
  • 事件:Celery 支持事件处理,可以自定义事件处理器来响应特定的事件。

以上是使用 Celery 的基本指南。根据实际需求,可能还需要进一步探索 Celery 的高级特性和配置选项。

http://www.lryc.cn/news/474919.html

相关文章:

  • vue中的nextTick() - 2024最新版前端秋招面试短期突击面试题【100道】
  • 5G学习笔记三之物理层、数据链路层、RRC层协议
  • Ubuntu 通过Supervisor 或者 systemd 管理 .Net应用
  • 超好用的视频剪辑软件分享:10款剪辑软件推荐
  • 5G三大应用场景中的URLLC
  • PyMOL中常用的命令列表
  • 坏块处理 ORA-01578: ORACLE data block corrupted (file # 3, block # 152588)
  • 像`npm i`作为`npm install`的简写一样,使用`pdm i`作为`pdm install`的简写
  • DNS域名解析服务器--RHCE
  • 数据库物化视图的工作原理与Java实现
  • 炫酷的登录框!(附源码)
  • 使用Python实现智能生态系统监测与保护的深度学习模型
  • Rust 力扣 - 54. 螺旋矩阵
  • Flutter 简述(1)
  • BGP实验--BGP路由反射器
  • 域渗透-域环境部署
  • 【Oracle】空格单字符通配符查询匹配失败
  • uniapp实现中间平滑凸起tabbar
  • 【视频】OpenCV:识别颜色、绘制轮廓
  • C++_STL_xx_番外01_关于STL的总结(常见容器的总结;关联式容器分类及特点;二叉树、二叉搜索树、AVL树(平衡二叉搜索树)、B树、红黑树)
  • xlrd.biffh.XLRDError: Excel xlsx file; not supported
  • ENNSP中ACL的实验配置
  • 数字后端零基础入门系列 | Innovus零基础LAB学习Day8
  • 【AI开源项目】FastGPT- 快速部署FastGPT以及使用知识库的两种方式!
  • 信息学科平台系统开发:Spring Boot实用指南
  • 笔记本电脑买i7还是i9?i7和i9处理器区别详细介绍
  • Netty原来就是这样啊(一)
  • 量子容错计算
  • QGraphics View坐标系
  • 繁星之下--