pub struct TpsBudget { /* private fields */ }Expand description
A Transactions Per Minute config for managing retry tokens.
TpsBudget uses a token bucket to decide if the request should be retried.
TpsBudget works by checking how much retries have been made in a certain period of time.
Minimum allowed number of retries are effectively reset on an interval. Allowed number of
retries depends on failed request count in recent time frame.
For more info about Budget, please see the module-level documentation.
Implementations§
Source§impl TpsBudget
impl TpsBudget
Sourcepub fn new(ttl: Duration, min_per_sec: u32, retry_percent: f32) -> Self
pub fn new(ttl: Duration, min_per_sec: u32, retry_percent: f32) -> Self
Create a TpsBudget that allows for a certain percent of the total
requests to be retried.
-
The
ttlis the duration of how long a singledepositshould be considered. Must be between 1 and 60 seconds. -
The
min_per_secis the minimum rate of retries allowed to accommodate clients that have just started issuing requests, or clients that do not issue many requests per window. -
The
retry_percentis the percentage of calls todepositthat can be retried. This is in addition to any retries allowed for viamin_per_sec. Must be between 0 and 1000.As an example, if
0.1is used, then for every 10 calls todeposit, 1 retry will be allowed. If2.0is used, then everydepositallows for 2 retries.