Skip to main content

A simple Python library for retrying functions with various backoff and callback strategies.

Project description

retry

A simple, yet powerful, generic retry decorator in Python for retrying functions with various backoff and callback strategies.

Features:

  • Exception Handling: Retry based on specific exceptions.
  • Maximum Retries: Set the maximum number of retry attempts.
  • Timeout: Specify the maximum time to spend on retries. Timeout check happens right before retry execution of the wrapped function.
  • Deadline: Define a deadline for retries to complete. Deadline check happens right after the retry execution of the wrapped function.
  • Backoff Strategies: Choose from various backoff strategies: fixed, exponential, linear, random
  • Retry Callback: Execute a callback function between retry attempts.
  • Successful Retry Callback: Perform an action after a successful retry.
  • Failure Callback: Define a callback function after failing all retries.
  • Logging control: Define which logger (or no logger) to use for logging retries and exceptions.

API

  • Decorator: retry
  • Retry exceptions: MaxRetriesException, RetriesTimeoutException, RetriesDeadlineException
  • Callback factory: CallbackFactory, callback_factory
  • Backoff strategies: FixedBackOff, LinearBackOff, ExponentialBackOff, RandomUniformBackOff

Examples

# public API
from retry import (
    retry,
    callback_factory,
    CallbackFactory,
    FixedBackOff,
    LinearBackOff,
    ExponentialBackOff,
    RandomUniformBackOff,
    MaxRetriesException,
    RetriesTimeoutException,
    RetriesDeadlineException
)
# Retry until maximum retries are reached
# no backoff strategy means the default will apply,
# which is 0 delay between retries
@retry((AssertionError,), max_retries=3)
def cause_max_retries_error():
    assert False
# Retry until timeout error after 2 seconds
# Fixed backoff strategy for 1 second delay between retries
@retry((ValueError,), timeout=2, backoff=FixedBackOff(base_delay=1))
def cause_timeout_error():
    raise ValueError
# Retry until deadline error after 3 seconds
# Not really retrying here, this will just execute once
# as the execution will take longer than deadline
@retry(deadline=3)
def cause_deadline_error():
    sleep(4)
# Retry until deadline error after 2 seconds
# Fixed backoff strategy for 1 second delay between retries
# Expected to retry twice and then succeed but restricted by deadline
@retry(
        (ValueError,),
        deadline=2,
        backoff=FixedBackOff(base_delay=1)
)
def cause_deadline_error_after_retries():
    if not hasattr(cause_deadline_error_after_retries, "call_count"):
        cause_deadline_error_after_retries.call_count = 0
    cause_deadline_error_after_retries.call_count += 1
    if cause_deadline_error_after_retries.call_count < 2:
        raise ValueError
    else:
        sleep(1)
# Retry until maximum retries are reached
# Random backoff strategy with an initial delay and
# limits for min and max delay in next retries
# Callback function between retries by passing a callable function
def retry_callback():
    logger.debug("Calling between retries")


@retry(
        (ValueError,),
        max_retries=3,
        backoff=RandomUniformBackOff(base_delay=0.3, min_delay=0.1, max_delay=0.5),
        retry_callback=retry_callback
)
def retry_with_callback():
    raise ValueError
# Retry indefinetely as there is no max retries, timeout
# or deadline specified
# Exponential backoff strategy with an initial delay of 1 second
# Parametrized callback with utility of package to call after successful retry
# Successful callback is expected after successful retry on 3rd round
def successful_retry_callback(value):
    logger.debug(f"Calling on successful retry with value: {value}")

successful_retry_callback_ = callback_factory(successful_retry_callback, "phew")

@retry(
        (ValueError,),
        backoff=ExponentialBackOff(base_delay=1),
        successful_retry_callback=successful_retry_callback_
)
def successful_retry_with_callback():
    if not hasattr(successful_retry_with_callback, "call_count"):
        successful_retry_with_callback.call_count = 0
    successful_retry_with_callback.call_count += 1
    if successful_retry_with_callback.call_count < 3:
        raise ValueError
# Retry until maximum retries are reached
# Linear backoff strategy with an initial delay of 0.1 second and 0.1 second as step
# Parametrized callback with utility of package to call after failure of all retries
# Failure callback is expected after failing all 3 retries
def failure_callback(value):
    logger.debug(f"Calling after failure of all retries with value: {value}")

failure_callback_ = CallbackFactory(failure_callback, value="wasted")

@retry(
        max_retries=3,
        backoff=LinearBackOff(base_delay=0.1, step=0.1),
        failure_callback=failure_callback_
)
def fail_with_callback():
    raise ValueError

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

retry-reloaded-0.0.1.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

retry_reloaded-0.0.1-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file retry-reloaded-0.0.1.tar.gz.

File metadata

  • Download URL: retry-reloaded-0.0.1.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for retry-reloaded-0.0.1.tar.gz
Algorithm Hash digest
SHA256 4e87ae030f5c1a8f6a7156012f8e01a175e1d9aa34eaee8b9f18f1ba228258c0
MD5 198b69eeabe887b2c55913367827ffdc
BLAKE2b-256 2b82cfb99d9bd252589a3b1810836ed8d3f8b14e4cd332e9ab737c6c016a45e2

See more details on using hashes here.

File details

Details for the file retry_reloaded-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for retry_reloaded-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d892fc83678561dc95ce350b2569553bd4492667faed586574cba6dacb70c4bf
MD5 89b50981f17a6100dca3f15a7c0429b8
BLAKE2b-256 3db027a3b0fff09b8cc09a4497b5f4633a11ec612cc09973432ce57068d13845

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page