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§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§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> 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