pub struct ClusterManager { /* private fields */ }Expand description
Comprehensive cluster management system
Implementations§
Source§impl ClusterManager
impl ClusterManager
Sourcepub fn new(config: ClusterConfiguration) -> CoreResult<Self>
pub fn new(config: ClusterConfiguration) -> CoreResult<Self>
Create new cluster manager
Sourcepub fn global() -> CoreResult<Arc<Self>>
pub fn global() -> CoreResult<Arc<Self>>
Get global cluster manager instance
Sourcepub fn start(&self) -> CoreResult<()>
pub fn start(&self) -> CoreResult<()>
Start cluster management services
Sourcepub fn register_node(&self, nodeinfo: NodeInfo) -> CoreResult<()>
pub fn register_node(&self, nodeinfo: NodeInfo) -> CoreResult<()>
Register a new node in the cluster
Sourcepub fn get_health(&self) -> CoreResult<ClusterHealth>
pub fn get_health(&self) -> CoreResult<ClusterHealth>
Get cluster health status
Sourcepub fn get_active_nodes(&self) -> CoreResult<Vec<NodeInfo>>
pub fn get_active_nodes(&self) -> CoreResult<Vec<NodeInfo>>
Get list of active nodes
Sourcepub fn get_available_nodes(&self) -> CoreResult<HashMap<String, NodeInfo>>
pub fn get_available_nodes(&self) -> CoreResult<HashMap<String, NodeInfo>>
Get available nodes (returns nodeid -> nodeinfo mapping)
Sourcepub fn get_total_capacity(&self) -> CoreResult<ComputeCapacity>
pub fn get_total_capacity(&self) -> CoreResult<ComputeCapacity>
Get total cluster compute capacity
Sourcepub fn submit_task(&self, task: DistributedTask) -> CoreResult<TaskId>
pub fn submit_task(&self, task: DistributedTask) -> CoreResult<TaskId>
Submit a distributed task to the cluster
Sourcepub fn get_cluster_statistics(&self) -> CoreResult<ClusterStatistics>
pub fn get_cluster_statistics(&self) -> CoreResult<ClusterStatistics>
Get cluster statistics
Sourcepub fn stop(&self) -> CoreResult<()>
pub fn stop(&self) -> CoreResult<()>
Stop the cluster manager and all background threads
Sourcepub fn get_configuration(&self) -> CoreResult<ClusterConfiguration>
pub fn get_configuration(&self) -> CoreResult<ClusterConfiguration>
Get cluster configuration
Sourcepub fn update_configuration(
&self,
new_config: ClusterConfiguration,
) -> CoreResult<()>
pub fn update_configuration( &self, new_config: ClusterConfiguration, ) -> CoreResult<()>
Update cluster configuration
Sourcepub fn get_cluster_state(&self) -> CoreResult<String>
pub fn get_cluster_state(&self) -> CoreResult<String>
Get cluster state
Sourcepub fn force_leader_election(&self) -> CoreResult<Option<String>>
pub fn force_leader_election(&self) -> CoreResult<Option<String>>
Force leader election
Sourcepub fn remove_node(&self, node_id: &str) -> CoreResult<()>
pub fn remove_node(&self, node_id: &str) -> CoreResult<()>
Remove a node from the cluster
Sourcepub fn shutdown_node(&self, node_id: &str) -> CoreResult<()>
pub fn shutdown_node(&self, node_id: &str) -> CoreResult<()>
Gracefully shutdown a node
Trait Implementations§
Auto Trait Implementations§
impl Freeze for ClusterManager
impl RefUnwindSafe for ClusterManager
impl Send for ClusterManager
impl Sync for ClusterManager
impl Unpin for ClusterManager
impl UnwindSafe for ClusterManager
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> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Casts the value.
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> 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 moreSource§impl<T> OverflowingAs for T
impl<T> OverflowingAs for T
Source§fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
Source§fn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
Casts the value.
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> SaturatingAs for T
impl<T> SaturatingAs for T
Source§fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
Source§fn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.Source§impl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
Source§fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
Source§fn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Source§impl<T> WrappingAs for T
impl<T> WrappingAs for T
Source§fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
Source§fn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
Casts the value.