3

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

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

我的最终目标是实现类似的东西:

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

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

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

4

1 回答 1

8

将使用任务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

对于延迟尝试:

request = webapp2.get_request()
于 2013-10-25T01:40:09.893 回答