pub struct Balance<D, Req>{ /* private fields */ }Expand description
Efficiently distributes requests across an arbitrary number of services.
See the module-level documentation for details.
Note that Balance requires that the Discover you use is Unpin in order to implement
Service. This is because it needs to be accessed from Service::poll_ready, which takes
&mut self. You can achieve this easily by wrapping your Discover in Box::pin before you
construct the Balance instance. For more details, see #319.
Implementations§
Trait Implementations§
source§impl<D, Req> Service<Req> for Balance<D, Req>
 
impl<D, Req> Service<Req> for Balance<D, Req>
§type Response = <<D as Discover>::Service as Service<Req>>::Response
 
type Response = <<D as Discover>::Service as Service<Req>>::Response
Responses given by the service.
§type Future = MapErr<<<D as Discover>::Service as Service<Req>>::Future, fn(_: <<D as Discover>::Service as Service<Req>>::Error) -> Box<dyn Error + Sync + Send>>
 
type Future = MapErr<<<D as Discover>::Service as Service<Req>>::Future, fn(_: <<D as Discover>::Service as Service<Req>>::Error) -> Box<dyn Error + Sync + Send>>
The future response value.
Auto Trait Implementations§
impl<D, Req> !Freeze for Balance<D, Req>
impl<D, Req> !RefUnwindSafe for Balance<D, Req>
impl<D, Req> Send for Balance<D, Req>
impl<D, Req> Sync for Balance<D, Req>
impl<D, Req> Unpin for Balance<D, Req>
impl<D, Req> !UnwindSafe for Balance<D, Req>
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<M, S, Target, Request> MakeService<Target, Request> for M
 
impl<M, S, Target, Request> MakeService<Target, Request> for M
source§fn poll_ready(
    &mut self,
    cx: &mut Context<'_>
) -> Poll<Result<(), <M as MakeService<Target, Request>>::MakeError>>
 
fn poll_ready( &mut self, cx: &mut Context<'_> ) -> Poll<Result<(), <M as MakeService<Target, Request>>::MakeError>>
Returns 
Poll::Ready when the factory is able to create more services. Read moresource§fn make_service(
    &mut self,
    target: Target
) -> <M as MakeService<Target, Request>>::Future
 
fn make_service( &mut self, target: Target ) -> <M as MakeService<Target, Request>>::Future
Create and return a new service value asynchronously.
source§fn into_service(self) -> IntoService<Self, Request>where
    Self: Sized,
 
fn into_service(self) -> IntoService<Self, Request>where
    Self: Sized,
source§fn as_service(&mut self) -> AsService<'_, Self, Request>where
    Self: Sized,
 
fn as_service(&mut self) -> AsService<'_, Self, Request>where
    Self: Sized,
source§impl<T, Request> ServiceExt<Request> for T
 
impl<T, Request> ServiceExt<Request> for T
source§fn ready(&mut self) -> Ready<'_, Self, Request> ⓘwhere
    Self: Sized,
 
fn ready(&mut self) -> Ready<'_, Self, Request> ⓘwhere
    Self: Sized,
Yields a mutable reference to the service when it is ready to accept a request.
source§fn ready_and(&mut self) -> ReadyAnd<'_, Self, Request>where
    Self: Sized,
 
fn ready_and(&mut self) -> ReadyAnd<'_, Self, Request>where
    Self: Sized,
👎Deprecated since 0.4.6: please use the 
ServiceExt::ready method insteadYields a mutable reference to the service when it is ready to accept a request.
source§fn ready_oneshot(self) -> ReadyOneshot<Self, Request> ⓘwhere
    Self: Sized,
 
fn ready_oneshot(self) -> ReadyOneshot<Self, Request> ⓘwhere
    Self: Sized,
Yields the service when it is ready to accept a request.
source§fn oneshot(self, req: Request) -> Oneshot<Self, Request> ⓘwhere
    Self: Sized,
 
fn oneshot(self, req: Request) -> Oneshot<Self, Request> ⓘwhere
    Self: Sized,
Consume this 
Service, calling with the providing request once it is ready.source§fn and_then<F>(self, f: F) -> AndThen<Self, F>
 
fn and_then<F>(self, f: F) -> AndThen<Self, F>
Executes a new future after this service’s future resolves. This does
not alter the behaviour of the 
poll_ready method. Read moresource§fn map_response<F, Response>(self, f: F) -> MapResponse<Self, F>
 
fn map_response<F, Response>(self, f: F) -> MapResponse<Self, F>
Maps this service’s response value to a different value. This does not
alter the behaviour of the 
poll_ready method. Read moresource§fn map_err<F, Error>(self, f: F) -> MapErr<Self, F>
 
fn map_err<F, Error>(self, f: F) -> MapErr<Self, F>
Maps this service’s error value to a different value. This does not
alter the behaviour of the 
poll_ready method. Read moresource§fn map_result<F, Response, Error>(self, f: F) -> MapResult<Self, F>
 
fn map_result<F, Response, Error>(self, f: F) -> MapResult<Self, F>
Maps this service’s result type (
Result<Self::Response, Self::Error>)
to a different value, regardless of whether the future succeeds or
fails. Read moresource§fn map_request<F, NewRequest>(self, f: F) -> MapRequest<Self, F>
 
fn map_request<F, NewRequest>(self, f: F) -> MapRequest<Self, F>
Composes a function in front of the service. Read more
source§fn then<F, Response, Error, Fut>(self, f: F) -> Then<Self, F>
 
fn then<F, Response, Error, Fut>(self, f: F) -> Then<Self, F>
Composes an asynchronous function after this service. Read more
source§fn map_future<F, Fut, Response, Error>(self, f: F) -> MapFuture<Self, F>
 
fn map_future<F, Fut, Response, Error>(self, f: F) -> MapFuture<Self, F>
Composes a function that transforms futures produced by the service. Read more