From 977120d83a0888837f0c119ed858bb756e5aec16 Mon Sep 17 00:00:00 2001 From: Hynek Schlawack Date: Sat, 21 Oct 2023 07:18:12 +0200 Subject: [PATCH] docs: add formula to motivation, too --- docs/motivation.md | 8 +++++++- src/stamina/_core.py | 1 + 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/docs/motivation.md b/docs/motivation.md index 2ee1924..7bcfb17 100644 --- a/docs/motivation.md +++ b/docs/motivation.md @@ -27,8 +27,14 @@ You start with a small backoff and increase it exponentially, adding a random ji That's what *stamina* does by default: It starts with 100ms and increases exponentially by 2 until it reaches 45 seconds or 10 attempts. A jitter between 0 and 1 second is added at every step. +Or, more formally: -That means the first backoff is no longer than 1.1 seconds, and the last is no longer than 46 seconds. +% keep in-sync with stamina.retry's docstring +```{math} +wait\_initial * wait\_exp\_base^{attempt - 1} + random(0, wait\_jitter) +``` + +That means that, by default, the first backoff is no longer than 1.1 seconds, and the last is no longer than 46 seconds. You can [tune all these parameters](stamina.retry) to your liking, but the defaults are a good starting point. --- diff --git a/src/stamina/_core.py b/src/stamina/_core.py index f15b77b..467d1e9 100644 --- a/src/stamina/_core.py +++ b/src/stamina/_core.py @@ -275,6 +275,7 @@ def retry( The backoff for retry attempt number *attempt* is computed as: + .. keep in-sync with docs/motivation.md .. math:: wait\_initial * wait\_exp\_base^{attempt - 1} + random(0, wait\_jitter)