Struct LockPrefix

Source
pub struct LockPrefix<'a> { /* private fields */ }
Expand description

Prefix pattern for lock path creation.

This struct carries path prefix for ephemeral lock path, name filter for candidate contenders and hint to find created lock path in case of Error::ConnectionLoss.

Implementations§

Source§

impl<'a> LockPrefix<'a>

Source

pub fn new_curator(dir: &'a str, name: &'a str) -> Result<Self, Error>

Apache Curator compatible unique prefix pattern, the final lock path will be {dir}/_c_{uuid}-{name}{ephemeral_sequence}.

§Notable lock names
  • latch- for LeaderLatch.
  • lock- for LeaderSelector and InterProcessMutex.
Source

pub fn new_shared(prefix: &'a str) -> Result<Self, Error>

Shared path prefix, the final lock path will be {prefix}{ephemeral_sequence}.

§CAUTION

All contenders share same prefix, so concurrent contenders must not share same session client. Otherwise, the lock could be ruined in case of Error::ConnectionLoss as there is no way to differentiate contenders using same session.

§Notable usages
Source

pub fn new_custom(prefix: String, name: &'a str) -> Result<Self, Error>

Custom path prefix, the final lock path will be {prefix}{ephemeral_sequence}.

§CAUTION

Don’t reuse same prefix among clients with same session. See LockPrefix::new_shared for details.

§API

It is intentional for prefix parameter to be String but not impl Into<String> nor impl Into<Cow<'a, str>>, so to attract attention for best wish.

§Notable usages
  • Uses “{dir}/x-{session_id}-” as prefix and “x-” or “” as name for ZooKeeper java client’s WriteLock.

Trait Implementations§

Source§

impl<'a> Debug for LockPrefix<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for LockPrefix<'a>

§

impl<'a> RefUnwindSafe for LockPrefix<'a>

§

impl<'a> Send for LockPrefix<'a>

§

impl<'a> Sync for LockPrefix<'a>

§

impl<'a> Unpin for LockPrefix<'a>

§

impl<'a> UnwindSafe for LockPrefix<'a>

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

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
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