pub struct RateLimitedRouter<TRouter, TRateLimit> {
pub router: TRouter,
pub rate_limiter: TRateLimit,
}Expand description
A generic struct which wraps the message router and adds support for a rate-limiting implementation to rate limit jobs processed by the factory. This handles the plubming around wrapping a rate limited message router
Fields§
§router: TRouterThe underlying message router which does NOT implement rate limiting
rate_limiter: TRateLimitThe rate limiter to apply to the message routing
Implementations§
Source§impl<TRouter, TRateLimit> RateLimitedRouter<TRouter, TRateLimit>
impl<TRouter, TRateLimit> RateLimitedRouter<TRouter, TRateLimit>
Sourcepub fn builder() -> RateLimitedRouterBuilder<TRouter, TRateLimit>
pub fn builder() -> RateLimitedRouterBuilder<TRouter, TRateLimit>
Create an instance of RateLimitedRouter using the builder syntax
Trait Implementations§
Source§impl<TRouter, TRateLimit> Debug for RateLimitedRouter<TRouter, TRateLimit>
impl<TRouter, TRateLimit> Debug for RateLimitedRouter<TRouter, TRateLimit>
Source§impl<TKey, TMsg, TRouter, TRateLimit> Router<TKey, TMsg> for RateLimitedRouter<TRouter, TRateLimit>
impl<TKey, TMsg, TRouter, TRateLimit> Router<TKey, TMsg> for RateLimitedRouter<TRouter, TRateLimit>
Source§fn route_message(
&mut self,
job: Job<TKey, TMsg>,
pool_size: usize,
worker_hint: Option<usize>,
worker_pool: &mut HashMap<usize, WorkerProperties<TKey, TMsg>>,
) -> Result<RouteResult<TKey, TMsg>, Box<dyn Error + Sync + Send>>
fn route_message( &mut self, job: Job<TKey, TMsg>, pool_size: usize, worker_hint: Option<usize>, worker_pool: &mut HashMap<usize, WorkerProperties<TKey, TMsg>>, ) -> Result<RouteResult<TKey, TMsg>, Box<dyn Error + Sync + Send>>
Auto Trait Implementations§
impl<TRouter, TRateLimit> Freeze for RateLimitedRouter<TRouter, TRateLimit>
impl<TRouter, TRateLimit> RefUnwindSafe for RateLimitedRouter<TRouter, TRateLimit>where
TRouter: RefUnwindSafe,
TRateLimit: RefUnwindSafe,
impl<TRouter, TRateLimit> Send for RateLimitedRouter<TRouter, TRateLimit>
impl<TRouter, TRateLimit> Sync for RateLimitedRouter<TRouter, TRateLimit>
impl<TRouter, TRateLimit> Unpin for RateLimitedRouter<TRouter, TRateLimit>
impl<TRouter, TRateLimit> UnwindSafe for RateLimitedRouter<TRouter, TRateLimit>where
TRouter: UnwindSafe,
TRateLimit: 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
Mutably borrows from an owned value. Read more
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>
Converts
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>
Converts
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 moreSource§impl<T> Message for T
impl<T> Message for T
Source§fn from_boxed(m: BoxedMessage) -> Result<Self, BoxedDowncastErr>
fn from_boxed(m: BoxedMessage) -> Result<Self, BoxedDowncastErr>
Convert a BoxedMessage to this concrete type
Source§fn box_message(self, pid: &ActorId) -> Result<BoxedMessage, BoxedDowncastErr>
fn box_message(self, pid: &ActorId) -> Result<BoxedMessage, BoxedDowncastErr>
Convert this message to a BoxedMessage