0X01 场景

celery任务超时报错,想查看是传入哪一类数据运行时导致的超时(哪一个插件),但是该报错难以拦截。

[2019-06-30 17:23:21,070: ERROR/MainProcess] Task tasks.sum[8c81398b-4378-401d-a674-a3bd3418ccde] raised unexpected: TimeLimitExceeded(5.0,)
Traceback (most recent call last):
File "/home/apernin/.virtualenvs/dr/local/lib/python2.7/site-packages/billiard/pool.py", line 645, in on_hard_timeout
raise TimeLimitExceeded(job._timeout)
TimeLimitExceeded: TimeLimitExceeded(5.0,)

该超时报错属于celery worker(MainProcess)调用时超时的报错,无法在任务中拦截。

0X02 方法

使用 soft_time_limit参数。

time_limit参数超时直接kill掉;

soft_time_limit参数超时时会报错而不会kill,可以捕获。

@app.task(name='tasks.main', bind=True, soft_time_limit=2, errback=error_fun)
def task_main(self, param):
try:
time.sleep(10)
except SoftTimeLimitExceeded as e:
print e
但是存在问题,windows下似乎无法使用soft_time_limit参数

把uuid以及相关信息在任务运行时都打印出来。

报错时会显示uuid。

短暂地拦截日志,再通过uuid关联,获取超时任务的信息。

bind将任务也绑定进来,可以通过self获取任务的相关信息。

@app.task(name='tasks.main', bind=True)
def task_main(self, param):
print str(self.request.id) + param

https://stackoverflow.com/questions/56819470/retrieving-celery-task-kwargs-from-task-failed-uuid?r=SearchResults

文中有事件监听的思路

最新文章

  1. PHP中使用CURL请求页面,使用fiddler进行抓包
  2. C语言 链表排序
  3. 测试Javacript里的checkbox是否被选中的status和checked的替换方法
  4. log4net在Asp.net Mvc中的应用配置与介绍
  5. STL之优先队列(1)
  6. MyDiary,《你的名字。》同款日记应用
  7. Hive(七):HQL DML
  8. event 关键字
  9. (转载)Java之外观模式(Facade Pattern)
  10. MFC使用Windows media player播放声音文件
  11. spark sql 以JDBC为数据源
  12. linux下Python网络编程框架-Twisted安装
  13. 第七章——DMVs和DMFs(2)——用DMV和DMF监控索引性能
  14. 1 Selenium打开浏览器
  15. java四大会话技术
  16. Java简历与面试
  17. JVM-高效并发
  18. 20175234 《Java程序设计》第二周学习总结(二)
  19. 有趣的canvas
  20. logging addHandler(console)

热门文章

  1. Asp.Net Core 调用第三方Open API查询物流数据
  2. uwsgi03----直接部署
  3. http拦截器-HandlerInterceptor
  4. Aes 加密解密 java加密解密
  5. Java调用SqlLoader将大文本导入数据库
  6. 利用Python进行数据分析 第6章 数据加载、存储与文件格式(2)
  7. PAT(B) 1089 狼人杀-简单版(Java)逻辑推理
  8. 彻底关闭networkmanager
  9. loginserver 个人草稿
  10. Quartz入门以及相关表达式使用