0

我有一个 Google App Engine cron 作业经常但并非总是失败,因为已达到 java servlet 的最大重试次数。Google App Engine 应用程序可以正常工作。

我的 servlet 如下所示,它通常会达到“重试次数过多”点,但并非总是如此。

它计划每隔几个小时运行一次,并且似乎由于等待应用程序的实例启动而失败,但我不确定。

我怎样才能解决这个问题?只是增加重试次数?如何调试以了解导致“重试次数过多”的原因?

public class SomeServlet extends BaseServlet {

        private static final String HEADER_QUEUE_COUNT = "X-AppEngine-TaskRetryCount";
        ...
        @Override
        protected void doPost(HttpServletRequest req, HttpServletResponse resp)
                        throws IOException {

                String retryCountHeader = req.getHeader(HEADER_QUEUE_COUNT);

                if (retryCountHeader != null) {
                        int retryCount = Integer.parseInt(retryCountHeader);
                        if (retryCount > 10) {
                                logger.severe("Too many retries, dropping task...");
                                taskDone(resp);
                                return;
                        }
                }
             ...
        }
4

1 回答 1

0

它失败是因为每次执行 cron 任务时 retryCount 都会继续增加。无法控制 Google App Engine cron 任务的重试。在上面的示例中,一旦执行了 10 个 cron 作业,servlet 将到达“重试次数过多”点。

如果需要重试控制,只需删除 retryCount 测试并将真正的 GAE 任务排入 cron 作业。

于 2013-08-14T15:09:53.957 回答