pub struct AssignmentSnapshot {
pub version: u64,
pub vnodes: BTreeMap<u32, NodeId>,
pub updated_at_ms: i64,
}Expand description
Durable vnode-to-instance assignment snapshot.
Fields§
§version: u64Monotonic version. Writers bump on each update.
vnodes: BTreeMap<u32, NodeId>Vnode id → owning instance. BTreeMap (not Vec) so snapshots
with different vnode_count are still deserializable — sparse
indices surface as missing keys the caller can diagnose.
updated_at_ms: i64Wall-clock timestamp of the last update, millis since epoch.
Implementations§
Source§impl AssignmentSnapshot
impl AssignmentSnapshot
Sourcepub fn next(&self, vnodes: BTreeMap<u32, NodeId>) -> Self
pub fn next(&self, vnodes: BTreeMap<u32, NodeId>) -> Self
Next snapshot with bumped version and current wall-clock time.
Sourcepub fn vnodes_from_vec(assignment: &[NodeId]) -> BTreeMap<u32, NodeId>
pub fn vnodes_from_vec(assignment: &[NodeId]) -> BTreeMap<u32, NodeId>
Convert a Vec<NodeId> (one entry per vnode id, dense) into the
BTreeMap shape this snapshot uses. Mirrors the layout returned
by rendezvous_assignment.
Sourcepub fn to_vnode_vec(&self, vnode_count: u32) -> Vec<NodeId>
pub fn to_vnode_vec(&self, vnode_count: u32) -> Vec<NodeId>
Dense Vec<NodeId> of length vnode_count. Missing entries (a
stale snapshot from a smaller vnode topology) are filled with
NodeId::UNASSIGNED so callers can detect the mismatch.
Trait Implementations§
Source§impl Clone for AssignmentSnapshot
impl Clone for AssignmentSnapshot
Source§fn clone(&self) -> AssignmentSnapshot
fn clone(&self) -> AssignmentSnapshot
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for AssignmentSnapshot
impl Debug for AssignmentSnapshot
Source§impl<'de> Deserialize<'de> for AssignmentSnapshot
impl<'de> Deserialize<'de> for AssignmentSnapshot
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
impl Eq for AssignmentSnapshot
Source§impl PartialEq for AssignmentSnapshot
impl PartialEq for AssignmentSnapshot
Source§fn eq(&self, other: &AssignmentSnapshot) -> bool
fn eq(&self, other: &AssignmentSnapshot) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for AssignmentSnapshot
impl Serialize for AssignmentSnapshot
impl StructuralPartialEq for AssignmentSnapshot
Auto Trait Implementations§
impl Freeze for AssignmentSnapshot
impl RefUnwindSafe for AssignmentSnapshot
impl Send for AssignmentSnapshot
impl Sync for AssignmentSnapshot
impl Unpin for AssignmentSnapshot
impl UnsafeUnpin for AssignmentSnapshot
impl UnwindSafe for AssignmentSnapshot
Blanket Implementations§
impl<T> Allocation for T
§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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. 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.