Celery使用小结

介绍

Celery 是异步任务调度工具就,或分布式任务队列(Distributed Task Queue),有多个worker。

Broker:中间人,所有任务放在broker中,worker到broker中提取任务执行。

这样系统为开环系统,broker无法知道任务执行情况,可使用backend broker获取任务执行结果,

broker:消息传输的中间件,即消息队列,发送和接收结果;

backend:数据库,存储消息接celery执行的消息及结果;可以是database 或cached。

celery 组成:消息中间件、任务执行单元、执行结果存储。

celery不提供消息服务,但可与其他消息中间件集成;

报错:daemonic processes are not allowed to have children

原代码使用了多进程(multiprocessing),在与其他代码合并使用时产生了如上报错。

根据新逻辑可以不使用multiprocessing处理,删除后报错解决。worker是celery提供的任务执行单元,并发的运行在分布式系统节点中。

如果不方便修改,可参考如下方法

方法一:通过-P设置其他celery运行方式,但其他方式不是多进程模式,可能会影响项目性能

-P POOL, --pool POOL  Pool implementation: prefork (default), eventlet, gevent or solo.

方法二:设置环境变量,允许守护进程创建子进程

先执行  export PYTHONOPTIMIZE=1,再运行celery;如果在supervisord中托管celery,可在supervisord的配置文件中添加environment=PYTHONOPTIMIZE=1。

注意:PYTHONOPTIMIZE=1允许守护进程创建子进程,当主进程结束,会带走守护子进程,但守护子进程还来不及带走守护子进程的子进程(即使设置了daemon = True),守护子进程的子进程将会成为孤儿进程,需要特殊处理。

放到celery运行的代码需要添加装饰器 

启动celery前需要对计划运行在celery队列中的函数添加装饰器,如@app_celery.task,这样celery才能找到该函数,否则在运行该函数时报错:Received unregistered task of type 'tasks.add'.,KeyError: 'tasks.add'。

task_time_limit及soft_task_time_limit的使用

时间限制的配置方法:

在装饰器中添加time_limit的时间显示,其优先级高于配置文件,如:@app.task(time_limit=10)

在配置文件中设置超时的字段如下:

CELERYD_TASK_SOFT_TIME_LIMIT 
CELERYD_TASK_TIME_LIMIT

soft_time_limit 会在内部抛一个 Exception, hard time limit 没法被 catch.

celery pool 用的是 gevent, 现在的实现里 gevent 做 worker pool 的时候会忽略 soft_time_limit, 只有 hard_time_limit 会被触发(通过 gevent.Timeout 实现).

@app.task
def add(x, y):
    try:
        time.sleep(10)
        return x + y
    except SoftTimeLimitExceeded as stle:
        print(f"error: {stle}")
    except Exception as e:
        print(f"error: {e}")

如果出现soft超时异常,其报错信息显示在启动celery的界面,如果设置了保存结果的地址,如在redis中,因其异常已经捕获,其状态为success,但结果为空,如下:

如果出现hard超时异常,执行结果的状态为failure,异常被抛出,无法做后续处理:

查看celery中任务的数量及状态

1.  使用celery命令查看启动的应用(tasks)下正在执行的任务:celery -A tasks inspect active

2. 加入celery的任务,在执行delay()方法后会返回一个AsyncResult的类,包含任务的celery_task_id,可通过遍历的方法获取现有任务的状态。

3. 使用Flower监控工具

pip install flower,启动:celery -A tasks flower --port=5555

可在http://localhost:5555中查看到celery的状态和信息。

失败任务重试

参考:

Celery中文文档

Configuration and defaults — Celery 4.4.7 documentation

解决celery报错daemonic processes are not allowed to have children-CSDN博客

查询celery正在执行的任务_celery查看任务状态-CSDN博客

python celery 失败任务重试 python的celery_mob6454cc6ff2b9的技术博客_51CTO博客

Celery Time Limit 的坑 · Shining Moon (monsterxx03.com)

python 异步任务 开始 停止 python异步任务框架_mob64ca140d61c6的技术博客_51CTO博客

Celery 分布式任务队列_celery查看任务队列-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/930372.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java注解(二):注解的解析以及应用场景、用注解和反射模拟junit框架代码演示

目录 1、什么是注解的解析? 2、解析注解的案例 1、自定义一个注解 2、在类和方法上使用自己定义的注解 3、解析注解 3、模拟Junit框架案例 1、自定义一个MyTest注解 2、定义一个测试类,使用自定义的注解 3、写一个启动类 本文章主要讲解什么是注…

VUE脚手架练习

脚手架安装的问题: 1.安装node.js,配置环境变量,cmd输入node -v和npm -v可以看到版本号(如果显示不是命令,确认环境变量是否配置成功,记得配置环境变量之后重新打开cmd,再去验证) 2.在安装cnmp时&#xf…

unity3d—demo(实现给出图集名字和图片名字生成对应的图片)

目录 实现给出图集名字和图片名字生成对应的图片: 代码示例: dic: 键 是图集名称 值是一个字典 该字典键是图片名称 值是图片,结构如图: 测试代码: 结果: SpriteRenderer 讲解: Resour…

国内外网络安全政策动态(2024年11月)

▶︎ 1.13项网络安全国家标准自11月1日起实施 11月1日起,《网络安全技术 信息技术安全评估准则》等13项网络安全国家标准开始实施,其中,《网络安全技术 信息技术安全评估准则 第1-5部分》《网络安全技术 信息技术安全评估方法》等6项推荐性国…

Modbus Poll的使用

最近从串口调试助手接触到了Modbus Poll,一开始用的时候有些生疏,了解之后不得不说真香。 相对于串口调试助手,有些设备厂家会给一些点表和指令码,有些也可以通过modbus协议解析出来,相对来说,使用Modbus …

写NFC标签支持Android安卓Ohos纯血鸿蒙唤醒微信小程序

本示例使用的发卡器:https://item.taobao.com/item.htm?spma21dvs.23580594.0.0.52de2c1b8bEEGz&ftt&id61539185785 Python languagecodestr "en".encode(gbk) titlestrself.lineEdit_title.text().strip().encode(gbk) uriheaderindex sel…

利用oracle spool配置数据导出脚本

一,spool配置项 set colsep |   //域输出分隔符 set echo off   //显示start启动的脚本中的每个sql命令,缺省为on set feedback off //回显本次sql命令处理的记录条数,缺省为on set heading off  //输出域标题,缺省为on…

单端和差分信号的接线法

内容来源:【单端信号 差分信号与数据采集卡的【RSE】【 NRES】【 DIFF】 模式的连接】 此篇文章仅作笔记分享。 单端输入 单端信号指的是输入信号由一个参考端和一个信号端构成,参考端一般是地端,信号就是通过计算信号端口和地端的差值所得…

前端基础——CSS

美化文档 HTML内部添加样式 本节我们来学习如何在标签中引入CSS样式。 1 在标签中添加声明 声明的关键字是style后接等号&#xff08;&#xff09;再接引号&#xff08;""&#xff09;&#xff0c;即style"" 具体声明如下&#xff1a; <input typ…

MATLAB 最小二乘点云拟合球 (89)

MATLAB 最小二乘点云拟合球 (89) 一、算法介绍二、算法实现1.代码2.结果这是缘,亦是最美的相见 一、算法介绍 球面拟合算法是一种通过数学方法将一组三维点(通常在三维空间中分布)拟合到一个理想的球形表面上。这个过程通常涉及使用最小二乘法来最小化实际数据点与拟合的…

安防视频监控平台Liveweb视频汇聚管理系统管理方案

智慧安防监控Liveweb视频管理平台能在复杂的网络环境中&#xff0c;将前端设备统一集中接入与汇聚管理。国标GB28181协议视频监控/视频汇聚Liveweb平台可以提供实时远程视频监控、视频录像、录像回放与存储、告警、语音对讲、云台控制、平台级联、磁盘阵列存储、视频集中存储、…

elasticsearch-如何给文档新增/更新的字段

文章目录 前言elasticsearch-如何给文档新增/更新的字段1. 如何给某些文档新增/更新的字段2. 给所有文档添加/更新一个新的字段3. 测试 前言 如果您觉得有用的话&#xff0c;记得给博主点个赞&#xff0c;评论&#xff0c;收藏一键三连啊&#xff0c;写作不易啊^ _ ^。   而且…

浅谈网络 | 应用层之流媒体与P2P协议

目录 流媒体名词系列视频的本质视频压缩编码过程如何在直播中看到帅哥美女&#xff1f;RTMP 协议 P2PP2P 文件下载种子文件 (.torrent)去中心化网络&#xff08;DHT&#xff09;哈希值与 DHT 网络DHT 网络是如何查找 流媒体 直播系统组成与协议 近几年直播比较火&#xff0c;…

性能测试基础知识jmeter使用

博客主页&#xff1a;花果山~程序猿-CSDN博客 文章分栏&#xff1a;测试_花果山~程序猿的博客-CSDN博客 关注我一起学习&#xff0c;一起进步&#xff0c;一起探索编程的无限可能吧&#xff01;让我们一起努力&#xff0c;一起成长&#xff01; 目录 性能指标 1. 并发数 (Con…

【机器学习】机器学习的基本分类-监督学习-决策树-ID3 算法

ID3&#xff08;Iterative Dichotomiser 3&#xff09;是决策树的一种构造算法&#xff0c;由 Ross Quinlan 在 1986 年提出。它主要用于分类问题&#xff0c;通过信息增益选择特征来构建决策树。ID3 假设数据是离散型特征&#xff0c;且不支持连续型数据。 1. 核心思想 划分标…

记录:ubuntu 使用chattts的过程。

你知道什么是穷人吗&#xff1f;穷人就是没钱还想学习。 git GitHub - 2noise/ChatTTS: A generative speech model for daily dialogue. 因为所以。cosyvoice&#xff0c;gpt-s . 0.先找一个目录吧。 1.命令行模式 duyichengduyicheng-computer:~/gitee$ git clone https:…

LabVIEW氢同位素单质气体定量分装系统

氢同位素单质气体在多个行业中有重要应用&#xff0c;如能源和化工。传统的分装方法面临精度和自动化程度不足的问题。为此&#xff0c;开发了一套基于LabVIEW和质量流量控制器的定量分装系统&#xff0c;提高分装精度和效率&#xff0c;同时减少资源浪费和环境污染。 项目背景…

分类预测 | PSO-PNN粒子群优化概率神经网络多特征分类预测

分类预测 | PSO-PNN粒子群优化概率神经网络多特征分类预测 目录 分类预测 | PSO-PNN粒子群优化概率神经网络多特征分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现PSO-PNN粒子群优化概率神经网络多特征分类预测&#xff0c;运行环境Matlab2018b及以…

鸿蒙开发-Divider 组件

在 ArkTS 中&#xff0c;Divider组件是用于在界面上显示分割线的组件&#xff0c;以下是其详细介绍&#xff1a; 基本功能 Divider组件主要用于将页面中的不同部分进行视觉上的分隔&#xff0c;使页面布局更加清晰和有条理&#xff0c;增强用户界面的可读性和美观性。 常用属…

SpringBoot实战——个人博客项目

目录 一、项目简介 ?二、项目整体架构 数据库模块 后端模块 前端模块 ?三、项目具体展示 ?四、项目的具体实现 1、一些准备工作 ??数据库、数据表的创建 ??设置数据库和MyBatis的配置 ??将前端项目引入到当前项目中 2、登录注册模块 ??实体类的创建 ?…