在GAE中的deferred.defer中重试计数

时间:2013-10-25 01:27:18

标签: python google-app-engine

我正在使用GAE的“deffered”库(python),它会在发生异常时自动重试任务。

有没有办法知道(在任务处理函数中)任务被尝试的次数?

我的最终目标是实现以下内容:

if num_tries >5:
  email_admins()
  raise deferred.PermanentTaskFailure

最初我认为我可以使用'TaskRetryOptions'来限制尝试次数,但我相信这并没有为我的email_admins()调用提供机制。或者是吗?

[编辑]当然我可以读取/写入DB或memcache的尝试次数,但我更愿意避免这种复杂性。如果可能的话,我更愿意从任务/任务队列中获取详细信息。

1 个答案:

答案 0 :(得分:7)

有几个标题将自动设置任务 https://developers.google.com/appengine/docs/python/taskqueue/overview-push

  

X-AppEngine-TaskRetryCount,此任务的次数   重试;对于第一次尝试,此值为0.此数字包括   由于缺少可用实例而导致任务失败的尝试   并且从未达到执行阶段。

     

X-AppEngine-TaskExecutionCount,此任务在执行阶段之前失败的次数。此数字不包括由于缺少可用实例而导致的失败。

编辑1

这些值可以访问:

num_tries  = self.request.headers.get('X-AppEngine-TaskRetryCount')

编辑2

http://webapp-improved.appspot.com/api/webapp2.html#webapp2.get_request

为deferred尝试:

request = webapp2.get_request()