Struct CpuSetController

Source
pub struct CpuSetController { /* private fields */ }
Expand description

A controller that allows controlling the cpuset subsystem of a Cgroup.

In essence, this controller is responsible for restricting the tasks in the control group to a set of CPUs and/or memory nodes.

Implementations§

Source§

impl CpuSetController

Source

pub fn new(root: PathBuf, v2: bool) -> Self

Contructs a new CpuSetController with root serving as the root of the control group.

Source

pub fn cpuset(&self) -> CpuSet

Returns the statistics gathered by the kernel for this control group. See the struct for more information on what information this entails.

Source

pub fn set_cpu_exclusive(&self, b: bool) -> Result<()>

Control whether the CPUs selected via set_cpus() should be exclusive to this control group or not.

Source

pub fn set_mem_exclusive(&self, b: bool) -> Result<()>

Control whether the memory nodes selected via set_memss() should be exclusive to this control group or not.

Source

pub fn set_cpus(&self, cpus: &str) -> Result<()>

Set the CPUs that the tasks in this control group can run on.

Syntax is a comma separated list of CPUs, with an additional extension that ranges can be represented via dashes.

Source

pub fn set_mems(&self, mems: &str) -> Result<()>

Set the memory nodes that the tasks in this control group can use.

Syntax is the same as with set_cpus().

Source

pub fn set_hardwall(&self, b: bool) -> Result<()>

Controls whether the control group should be “hardwalled”, i.e., whether kernel allocations should exclusively use the memory nodes set via set_mems().

Note that some kernel allocations, most notably those that are made in interrupt handlers may disregard this.

Source

pub fn set_load_balancing(&self, b: bool) -> Result<()>

Controls whether the kernel should attempt to rebalance the load between the CPUs specified in the cpus field of this control group.

Source

pub fn set_rebalance_relax_domain_level(&self, i: i64) -> Result<()>

Contorl how much effort the kernel should invest in rebalacing the control group.

See @CpuSet ’s similar field for more information.

Source

pub fn set_memory_migration(&self, b: bool) -> Result<()>

Control whether when using set_mems() the existing memory used by the tasks should be migrated over to the now-selected nodes.

Source

pub fn set_memory_spread_page(&self, b: bool) -> Result<()>

Control whether filesystem buffers should be evenly split across the nodes selected via set_mems().

Source

pub fn set_memory_spread_slab(&self, b: bool) -> Result<()>

Control whether the kernel’s slab cache for file I/O should be evenly split across the nodes selected via set_mems().

Source

pub fn set_enable_memory_pressure(&self, b: bool) -> Result<()>

Control whether the kernel should collect information to calculate memory pressure for control groups.

Note: This will fail with InvalidOperation if the current congrol group is not the root control group.

Trait Implementations§

Source§

impl Clone for CpuSetController

Source§

fn clone(&self) -> CpuSetController

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for CpuSetController

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a> From<&'a Subsystem> for &'a CpuSetController

Source§

fn from(sub: &'a Subsystem) -> &'a CpuSetController

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Controller for T
where T: ControllerInternal,

Source§

fn apply(&self, res: &Resources) -> Result<(), Error>

Apply a set of resources to the Controller, invoking its internal functions to pass the kernel the information.

Source§

fn create(&self)

Create this controller

Source§

fn set_notify_on_release(&self, enable: bool) -> Result<(), Error>

Set notify_on_release

Source§

fn set_release_agent(&self, path: &str) -> Result<(), Error>

Set release_agent

Source§

fn exists(&self) -> bool

Does this controller already exist?

Source§

fn delete(&self) -> Result<(), Error>

Delete the controller.

Source§

fn add_task(&self, pid: &CgroupPid) -> Result<(), Error>

Attach a task to this controller.

Source§

fn add_task_by_tgid(&self, pid: &CgroupPid) -> Result<(), Error>

Attach a task to this controller by thread group id.

Source§

fn procs(&self) -> Vec<CgroupPid>

Get the list of procs that this controller has.

Source§

fn tasks(&self) -> Vec<CgroupPid>

Get the list of tasks that this controller has.

Source§

fn set_cgroup_type(&self, cgroup_type: &str) -> Result<(), Error>

set cgroup.type

Source§

fn get_cgroup_type(&self) -> Result<String, Error>

get cgroup.type

Source§

fn control_type(&self) -> Controllers

Source§

fn path(&self) -> &Path

The file system path to the controller.
Source§

fn v2(&self) -> bool

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.