Connector

Struct Connector 

Source
pub struct Connector { /* private fields */ }
Expand description

Runs in the background, maintains no more than one active connection to a RabbitMQ cluster (referred to herein as current connection) identified by the given Handle. Exposes a cheaply clone-able Gateway, which any number of asynchronous tasks can use to retrieve a fresh Channel created in the current connection.

Fully encapsulates reconnection and clean-up logic. Reconnection is triggered whenever a channel is requested and this connector is unable to produce it (likely, because there is no connectivity to the RabbitMQ cluster). Reconnections are performed with an exponential backoff strategy. All connections are properly closed in the background before discarding.

The clients should keep their copy of Gateway and re-use it to request a new Channel whenever the previous channel seems to be no longer working (e.g., the underlying connection was lost). The clients should expect that the gateway may take a long or even indefinite time, depending on the RabbitMQ cluster availability.

This connector is integrated with AppSpindown: once the global AppContext is terminated, this connector will stop serving channels and will attempt to gracefully close the current connection.

Implementations§

Source§

impl Connector

Source

pub fn start(handle: impl AsRef<Handle>) -> Gateway

Creates a new Connector for the given Handle and sends it into background to lazily serve Channel requests via the returned Gateway, which can be cheaply cloned and shared across asynchronous tasks.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,