pub struct LeaderLeaseManager { /* private fields */ }Expand description
Periodically renews the leader lease and publishes the latest record on a watch channel so other tasks can gate on the fencing token.
Implementations§
Source§impl LeaderLeaseManager
impl LeaderLeaseManager
Sourcepub fn new(
store: Arc<LeaderLeaseStore>,
me: NodeId,
config: LeaderLeaseConfig,
) -> Self
pub fn new( store: Arc<LeaderLeaseStore>, me: NodeId, config: LeaderLeaseConfig, ) -> Self
Build a manager. The watch starts at None until the first tick.
Sourcepub fn lease_watch(&self) -> Receiver<Option<LeaderLease>>
pub fn lease_watch(&self) -> Receiver<Option<LeaderLease>>
Subscribe to the latest observed lease.
Sourcepub fn spawn(self, shutdown: CancellationToken) -> JoinHandle<()>
pub fn spawn(self, shutdown: CancellationToken) -> JoinHandle<()>
Spawn the renewal loop. Every renew_interval it try_acquires
and publishes the resulting lease — Acquired when we own it,
otherwise the Held record so followers learn the current
fencing token. Errors are logged and retried next tick. Stops
when shutdown is cancelled.
Trait Implementations§
Auto Trait Implementations§
impl !RefUnwindSafe for LeaderLeaseManager
impl !UnwindSafe for LeaderLeaseManager
impl Freeze for LeaderLeaseManager
impl Send for LeaderLeaseManager
impl Sync for LeaderLeaseManager
impl Unpin for LeaderLeaseManager
impl UnsafeUnpin for LeaderLeaseManager
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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 more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
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].§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.