Skip to main content

ShutdownCoordinator

Struct ShutdownCoordinator 

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

A shutdown coordinator for triggering, and optionally waiting for, tasks to shut down.

Callers register a ShutdownHandle, which can be awaited to observe shutdown being triggered, or checked synchronously via ShutdownHandle::is_triggered. When a handle is dropped, it reports completion back to the coordinator; this is what allows shutdown_and_wait to block until every outstanding handle has finished.

Shutdown is triggered either fire-and-forget, via shutdown, or blocking, via shutdown_and_wait.

§Shutdown on drop

Shutdown is also triggered implicitly on drop if it hasn’t already been triggered, to enforce that shutdown always happens even in exceptional circumstances. Shutdown on drop is fire-and-forget: when the coordinator’s drop logic has executed, there is no guarantee that all outstanding handles have also been dropped.

Implementations§

Source§

impl ShutdownCoordinator

Source

pub fn register(&mut self) -> ShutdownHandle

Registers and returns a new shutdown handle.

Source

pub fn shutdown(self)

Signals shutdown to all outstanding handles without waiting.

When it is desirable to wait until all outstanding handles have completed (been dropped), use shutdown_and_wait.

Source

pub async fn shutdown_and_wait(self)

Signals shutdown to all outstanding handles, waiting until all handles have completed (been dropped).

If there are no outstanding handles, this returns immediately.

Trait Implementations§

Source§

impl Default for ShutdownCoordinator

Source§

fn default() -> ShutdownCoordinator

Returns the “default value” for a type. Read more
Source§

impl Drop for ShutdownCoordinator

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

fn pin_drop(self: Pin<&mut Self>)

🔬This is a nightly-only experimental API. (pin_ergonomics)
Execute the destructor for this type, but different to Drop::drop, it requires self to be pinned. Read more

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<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> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<L> LayerExt<L> for L

Source§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> Track for T

§

fn track_resources(self, token: ResourceGroupToken) -> Tracked<Self>

Instruments this type by attaching the given resource group token, returning a Tracked wrapper. Read more
§

fn in_current_resource_group(self) -> Tracked<Self>

Instruments this type by attaching the current resource group, returning a Tracked wrapper. Read more
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<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