PHP 5 has reached end of support and will be
deprecated
on January 31, 2026. After deprecation, you won't be able to deploy PHP 5
applications, even if your organization previously used an organization policy to
re-enable deployments of legacy runtimes. Your existing PHP
5 applications will continue to run and receive traffic after their
deprecation date. We recommend that
you
migrate to the latest supported version of PHP.
Retrying Failed Push Tasks
Stay organized with collections
Save and categorize content based on your preferences.
Push tasks being processed via a task queue can fail for many reasons. If a handler
fails to execute a task (and therefore returns any HTTP status code outside of
the range 200–299), App Engine retries the task until it succeeds.
By default, the system gradually reduces the retry rate to avoid overloading your application with too many
requests, but schedules retry attempts to recur at a maximum of once per hour
until the task succeeds.
Retrying tasks
You can customize your own scheme for task retries by
adding the retry
parameters
element in queue.yaml
. This
addition allows you to specify the maximum number of times to retry failed tasks
in a specific queue. You can also set a time limit for retry attempts and
control the interval between attempts.
The following example demonstrates various retry scenarios:
- In
fooqueue
, tasks are retried up to seven times and for up to two days
from the first execution attempt. After both limits are passed, it fails
permanently.
- In
barqueue
, App Engine attempts to retry tasks, increasing the interval
linearly between each retry until reaching the maximum backoff and retrying
indefinitely at the maximum interval (so the intervals between requests are
10s, 20s, 30s, ..., 190s, 200s, 200s, ...).
- In
bazqueue
, the retry interval starts at 10s, then doubles three times,
then increases linearly, and finally retries indefinitely at the
maximum interval (so the intervals between requests are
10s, 20s, 40s, 80s, 160s, 240s, 300s, 300s, ...).
queue:
- name: fooqueue
rate: 1/s
retry_parameters:
task_retry_limit: 7
task_age_limit: 2d
- name: barqueue
rate: 1/s
retry_parameters:
min_backoff_seconds: 10
max_backoff_seconds: 200
max_doublings: 0
- name: bazqueue
rate: 1/s
retry_parameters:
min_backoff_seconds: 10
max_backoff_seconds: 300
max_doublings: 3
What's next
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-08-04 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-04 UTC."],[[["Push tasks in App Engine are automatically retried upon failure, with the system gradually reducing the retry rate to prevent application overload, up to a maximum of once per hour."],["Custom retry schemes can be configured using the `retry_parameters` element in `queue.yaml`, allowing control over the maximum number of retries, the retry time limit, and the interval between retries."],["Different retry strategies can be implemented, including fixed retry limits, linearly increasing retry intervals, and exponentially increasing intervals with a cap, as demonstrated by the `fooqueue`, `barqueue`, and `bazqueue` examples."],["This retry API is compatible with first-generation runtimes and can be used during upgrades to second-generation runtimes, with a separate migration guide for PHP 7/8 runtimes."]]],[]]