pub struct Node {
pub id: String,
pub ip: IpAddr,
pub last_seen: i64,
pub metadata: NodeMetadata,
}Expand description
Represents a node in the cluster.
Each node has a unique identifier, network address, and timestamp of when it was last seen by the cluster.
§Equality
Two nodes are considered equal if they have the same id and ip.
The last_seen timestamp and metadata are intentionally excluded from
equality checks to allow detecting actual state changes vs heartbeat updates.
§Metadata
The optional metadata field allows nodes to report arbitrary data
(CPU load, memory, custom metrics) that can be used by load balancers
for weighted routing decisions.
Fields§
§id: StringUnique identifier for this node
ip: IpAddrNetwork address of this node
last_seen: i64Unix timestamp (milliseconds) when this node was last seen
metadata: NodeMetadataOptional node metadata (CPU, memory, custom metrics) Defaults to null if not provided (backward compatible)
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Node
impl<'de> Deserialize<'de> for Node
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 Node
Auto Trait Implementations§
impl Freeze for Node
impl RefUnwindSafe for Node
impl Send for Node
impl Sync for Node
impl Unpin for Node
impl UnwindSafe for Node
Blanket Implementations§
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,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request