pub struct ResourceAllocator { /* private fields */ }Expand description
Resource allocation and management
Implementations§
Source§impl ResourceAllocator
impl ResourceAllocator
Sourcepub fn update_available_resources(
&mut self,
nodes: &[NodeInfo],
) -> CoreResult<()>
pub fn update_available_resources( &mut self, nodes: &[NodeInfo], ) -> CoreResult<()>
Update available resources based on current node status
Sourcepub fn allocate_resources(
&self,
requirements: &ResourceRequirements,
) -> CoreResult<ResourceAllocation>
pub fn allocate_resources( &self, requirements: &ResourceRequirements, ) -> CoreResult<ResourceAllocation>
Allocate resources based on requirements
Sourcepub fn optimize_resource_allocation(&mut self) -> CoreResult<()>
pub fn optimize_resource_allocation(&mut self) -> CoreResult<()>
Optimize resource allocation using the configured strategy
Sourcepub fn get_available_capacity(&self) -> ComputeCapacity
pub fn get_available_capacity(&self) -> ComputeCapacity
Get available capacity
Sourcepub fn available_capacity(&self) -> &ComputeCapacity
pub fn available_capacity(&self) -> &ComputeCapacity
Get reference to available capacity
Sourcepub fn attempt_consolidation(
&mut self,
_taskid: &TaskId,
_allocation: &ResourceAllocation,
) -> CoreResult<bool>
pub fn attempt_consolidation( &mut self, _taskid: &TaskId, _allocation: &ResourceAllocation, ) -> CoreResult<bool>
Attempt to consolidate an allocation onto fewer nodes
Sourcepub fn attempt_best_fit_pairing(
&mut self,
_taskid: &TaskId,
_allocation: &ResourceAllocation,
) -> CoreResult<bool>
pub fn attempt_best_fit_pairing( &mut self, _taskid: &TaskId, _allocation: &ResourceAllocation, ) -> CoreResult<bool>
Attempt to pair allocations for better fit
Sourcepub fn attempt_small_allocation_packing(
&mut self,
_taskid: &TaskId,
_allocation: &ResourceAllocation,
) -> CoreResult<bool>
pub fn attempt_small_allocation_packing( &mut self, _taskid: &TaskId, _allocation: &ResourceAllocation, ) -> CoreResult<bool>
Attempt to pack small allocations tightly
Sourcepub fn find_best_target_node(
&mut self,
_resources: &ComputeCapacity,
_underloaded_nodes: &[(String, f64)],
) -> CoreResult<Option<(String, f64)>>
pub fn find_best_target_node( &mut self, _resources: &ComputeCapacity, _underloaded_nodes: &[(String, f64)], ) -> CoreResult<Option<(String, f64)>>
Find the best target node for an allocation
Sourcepub fn attempt_allocation_migration(
&mut self,
_taskid: &TaskId,
_to_node: &str,
) -> CoreResult<bool>
pub fn attempt_allocation_migration( &mut self, _taskid: &TaskId, _to_node: &str, ) -> CoreResult<bool>
Attempt to migrate an allocation to a different node
Sourcepub fn attempt_allocation_spreading(
&mut self,
_taskid: &TaskId,
_allocation: &ResourceAllocation,
) -> CoreResult<bool>
pub fn attempt_allocation_spreading( &mut self, _taskid: &TaskId, _allocation: &ResourceAllocation, ) -> CoreResult<bool>
Attempt to spread an allocation across multiple nodes
Sourcepub fn set_allocation_strategy(&mut self, strategy: AllocationStrategy)
pub fn set_allocation_strategy(&mut self, strategy: AllocationStrategy)
Set allocation strategy
Sourcepub fn get_allocation_strategy(&self) -> AllocationStrategy
pub fn get_allocation_strategy(&self) -> AllocationStrategy
Get current allocation strategy
Sourcepub fn add_allocation(
&mut self,
task_id: TaskId,
allocation: ResourceAllocation,
)
pub fn add_allocation( &mut self, task_id: TaskId, allocation: ResourceAllocation, )
Add an allocation
Sourcepub fn remove_allocation(
&mut self,
task_id: &TaskId,
) -> Option<ResourceAllocation>
pub fn remove_allocation( &mut self, task_id: &TaskId, ) -> Option<ResourceAllocation>
Remove an allocation
Sourcepub fn get_allocations(&self) -> &HashMap<TaskId, ResourceAllocation>
pub fn get_allocations(&self) -> &HashMap<TaskId, ResourceAllocation>
Get all current allocations
Trait Implementations§
Source§impl Debug for ResourceAllocator
impl Debug for ResourceAllocator
Auto Trait Implementations§
impl Freeze for ResourceAllocator
impl RefUnwindSafe for ResourceAllocator
impl Send for ResourceAllocator
impl Sync for ResourceAllocator
impl Unpin for ResourceAllocator
impl UnwindSafe for ResourceAllocator
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.