我正在使用GAE的“deffered”库(python),它会在发生异常时自动重试任务。
有没有办法知道(在任务处理函数中)任务被尝试的次数?
我的最终目标是实现以下内容:
if num_tries >5:
email_admins()
raise deferred.PermanentTaskFailure
最初我认为我可以使用'TaskRetryOptions'来限制尝试次数,但我相信这并没有为我的email_admins()调用提供机制。或者是吗?
[编辑]当然我可以读取/写入DB或memcache的尝试次数,但我更愿意避免这种复杂性。如果可能的话,我更愿意从任务/任务队列中获取详细信息。
答案 0 :(得分:7)
有几个标题将自动设置任务 https://developers.google.com/appengine/docs/python/taskqueue/overview-push
X-AppEngine-TaskRetryCount,此任务的次数 重试;对于第一次尝试,此值为0.此数字包括 由于缺少可用实例而导致任务失败的尝试 并且从未达到执行阶段。
X-AppEngine-TaskExecutionCount,此任务在执行阶段之前失败的次数。此数字不包括由于缺少可用实例而导致的失败。
这些值可以访问:
num_tries = self.request.headers.get('X-AppEngine-TaskRetryCount')
http://webapp-improved.appspot.com/api/webapp2.html#webapp2.get_request
为deferred尝试:
request = webapp2.get_request()