在使用django集成celery进行了异步调度任务之后,如果想对失败的任务进行跟踪或者告警,怎么做?

这里提供一个亲测的方法。

1、任务callback

假如你想在任务执行失败的时候,打印错误信息并且发出报警,该怎么搞。有两个方法:

(1)link_error

(2)on_failure/on_success

link_error的方法比较爽,但是我没有亲测过,on_failure的方式,是当任务抛出异常的时候,会触发一些事件,提供给大家代码:

定义一个新类重写Task里的on_success和on_failure方法:

from celery.app.task import Task
class CallbackTask(Task): def __init__(self):
super(CallbackTask, self).__init__() def on_success(self, retval, task_id, args, kwargs):
try:
item_param= json.loads(args[0])
logger.info('[task_id] %s, [task_type] %s, finished successfully.' % (task_id, item_param.get('task_type')))
except Exception, ex:
logger.error(traceback.format_exc()) def on_failure(self, exc, task_id, args, kwargs, einfo):
try:
item_param = json.loads(args[0])
logger.error(('Task {0} raised exception: {1!r}\n{2!r}'.format(
task_id, exc, einfo.traceback)))
except Exception, ex:
logger.error(traceback.format_exc())

装饰器使用新类作为baseClass

from celery import task
from common.callback import CallbackTask logger = logging.getLogger(__name__) @task(base=CallbackTask)
def quota_check(item_param):
logger.info('start')
return

最新文章

  1. The specified framework 'Microsoft.NETCore.App', version '1.0.1' was not found 解决办法
  2. yii2框架原生的结合框架使用的图片上传
  3. [转载]hashmap hashtable 的区别
  4. SEO 相关知识
  5. c# 纯代码方式创建快捷方式
  6. hibernate - Initial SessionFactory creation failed.org.hibernate.HibernateException
  7. Docker - 运行 containers 使用在 swarm 模式下创建的 overlay 模式的 network
  8. mailto调用本地默认客户端发邮件
  9. H5与C3权威指南笔记--transition动画
  10. IDEA+Maven配置MyBatis的初体验(坑点总结)
  11. springdata find立即加载 get延迟加载 get返回的是一个动态代理对象 特点是 用的时候才会查询 否则不查询
  12. unique_ptr
  13. topcoder SRM642 div1 hard WheelofFortune
  14. UUID简介
  15. [C++]求解三元一次方程组
  16. EDK II之DXE Core框架简介
  17. 设计模式(10)--Facade(外观模式)--结构型
  18. X86和X64环境下的基本类型所占用的字节大小
  19. 解密DNSPOD应对DDoS攻击招式!
  20. kafka基本原理概述——patition与replication分配

热门文章

  1. 使用JavaScript循环嵌套解决各种图形
  2. 团队作业1--团队展示&选题(SNS)
  3. 201521123064 《Java程序设计》第5周学习总结
  4. Java:接口继承接口 (多继承机制)
  5. Hyperledger Fabric 1.0 从零开始(六)——创建Fabric多节点集群
  6. hibernate 查询方式汇总
  7. 简单CSS 布局
  8. python3中的编码与解码用法
  9. 教你在Java接口中定义方法
  10. struts2前后台交互