pub struct TokenBucket<I> { /* private fields */ }Expand description
A token bucket.
Calculations are performed at microsecond resolution.
You likely want to call refill() each time you want to access or perform an
operation on the token bucket.
This is partially inspired by tor’s token_bucket_ctr_t,
but the implementation is quite a bit different.
We use larger values here (for example u64),
and we aim to avoid drift when refills occur at times that aren’t exactly in period with the
refill rate.
It’s possible that we could relax these requirements to reduce memory usage and computation complexity, but that optimization should probably only be made if/when needed since it would make the code more difficult to reason about, and possibly more complex.
Implementations§
Source§impl<I: TokenBucketInstant> TokenBucket<I>
impl<I: TokenBucketInstant> TokenBucket<I>
Sourcepub fn new(config: &TokenBucketConfig, now: I) -> Self
pub fn new(config: &TokenBucketConfig, now: I) -> Self
A new TokenBucket with a given rate in tokens/second and a max token limit.
The bucket will initially be full.
The value max is commonly referred to as the “burst”.
Sourcepub fn drain(
&mut self,
count: u64,
) -> Result<BecameEmpty, InsufficientTokensError>
pub fn drain( &mut self, count: u64, ) -> Result<BecameEmpty, InsufficientTokensError>
Remove count tokens from the bucket.
Sourcepub fn claim(
&mut self,
count: u64,
) -> Result<ClaimedTokens<'_, I>, InsufficientTokensError>
pub fn claim( &mut self, count: u64, ) -> Result<ClaimedTokens<'_, I>, InsufficientTokensError>
Claim a number of tokens.
The claim will be held by the returned ClaimedTokens, and committed when dropped.
Note: You probably want to call refill() before this.
Sourcepub fn adjust(&mut self, now: I, config: &TokenBucketConfig)
pub fn adjust(&mut self, now: I, config: &TokenBucketConfig)
Adjust the refill rate and max tokens of the bucket.
The token bucket is refilled up to now before changing the rate.
If the new max is smaller than the existing number of tokens, the number of tokens will be reduced to the new max.
A rate and/or max of 0 is allowed.
Sourcepub fn tokens_available_at(
&self,
tokens: u64,
) -> Result<I, NeverEnoughTokensError>
pub fn tokens_available_at( &self, tokens: u64, ) -> Result<I, NeverEnoughTokensError>
An estimated time at which the bucket will have tokens available.
It is not guaranteed that tokens will be available at the returned time.
If there are already enough tokens available, a time in the past may be returned.
A value of None implies “never”,
for example if the refill rate is 0,
the bucket max is too small,
or the time is too large to be represented as an I.
Sourcepub fn refill(&mut self, now: I) -> BecameNonEmpty
pub fn refill(&mut self, now: I) -> BecameNonEmpty
Refill the bucket.
Trait Implementations§
Auto Trait Implementations§
impl<I> Freeze for TokenBucket<I>where
I: Freeze,
impl<I> RefUnwindSafe for TokenBucket<I>where
I: RefUnwindSafe,
impl<I> Send for TokenBucket<I>where
I: Send,
impl<I> Sync for TokenBucket<I>where
I: Sync,
impl<I> Unpin for TokenBucket<I>where
I: Unpin,
impl<I> UnsafeUnpin for TokenBucket<I>where
I: UnsafeUnpin,
impl<I> UnwindSafe for TokenBucket<I>where
I: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more