Djangae contains a small collection of utility functions which are useful on App Engine.
This is a helper for calling functions which may intermittently throw errors. It is useful for things such as performing Datastore transactions which may collide, or calling other APIs which may occasionally fail but that should succeed on a subsequent attempt.
retry( function, _catch=None, _attempts=3, _initial_wait=375, _max_wait=30000, _avoid_clashes=True, *function_args, **function_kwargs, )
Calls the given function, catching the given exception(s), and (re)tries up to a maximum of
If the initial call fails, it will wait
_initial_wait milliseconds before making the second attempt.
The wait will double on each subsequent retry, up to a maximum of
_catch defaults to:
( google.api_core.exceptions.GoogleAPIError, django.db.DatabaseError, )
_avoid_clashes is True (default) then a random time up to a second will be added after the first
retry (the retry time is still capped at
_max_wait). This is to help avoid situations where several
tasks collide, and then all back off for the same amount of time before clashing again.
A function decorator which routes the function through
@retry_on_error(_catch=None, _attempts=3, _initial_wait=375, _max_wait=30000) def my_function(): ...
retry_until_successful( function, _catch=None, _attempts=∞, _initial_wait=375, _max_wait=30000, *function_args, **function_kwargs )
The same as
_attempts is unlimited, so it will keep on retrying until either it succeeds or you hit an uncaught exception, such as the App Engine