Skip to content

Commit

Permalink
Fix cgroup v2 memory stat related panics
Browse files Browse the repository at this point in the history
When containers are terminated, cgroup v2 memory metrics under /sys/fs/cgroup may disappear.
Previously, kata-agent assumed these metrics always exist, leading to panics as reported in #138.

This commit returns default value (0) when memory metric files are missing.
This behaviour aligns with cgroup v1, which also defaults to 0 memory metric files are missing:
- Memory.limit_in_bytes which maps to m.max https://github.com/kata-containers/cgroups-rs/blob/main/src/memory.rs#L635
- Memory.soft_limit_in_bytes which maps to m.low https://github.com/kata-containers/cgroups-rs/blob/main/src/memory.rs#L661
- MemSwap.fail_cnt: https://github.com/kata-containers/cgroups-rs/blob/main/src/memory.rs#L631

Submitting a new PR because #116 does not handle MemSwap.fail_cnt, which will also cause panic.

Signed-off-by: Alex Man <[email protected]>
  • Loading branch information
alexman-stripe committed Sep 11, 2024
1 parent eb3e37a commit 48545da
Showing 1 changed file with 13 additions and 7 deletions.
20 changes: 13 additions & 7 deletions src/memory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -574,12 +574,18 @@ impl MemController {
// for v2
pub fn get_mem(&self) -> Result<SetMemory> {
let mut m: SetMemory = Default::default();
self.get_max_value("memory.high")
.map(|x| m.high = Some(x))?;
self.get_max_value("memory.low").map(|x| m.low = Some(x))?;
self.get_max_value("memory.max").map(|x| m.max = Some(x))?;
self.get_max_value("memory.min").map(|x| m.min = Some(x))?;

m.high = self
.get_max_value("memory.high")
.map_or(Some(MaxValue::Value(0)), |x| Some(x));
m.low = self
.get_max_value("memory.low")
.map_or(Some(MaxValue::Value(0)), |x| Some(x));
m.max = self
.get_max_value("memory.max")
.map_or(Some(MaxValue::Value(0)), |x| Some(x));
m.min = self
.get_max_value("memory.min")
.map_or(Some(MaxValue::Value(0)), |x| Some(x));
Ok(m)
}

Expand Down Expand Up @@ -730,7 +736,7 @@ impl MemController {
.open_path("memory.swap.events", false)
.and_then(flat_keyed_to_hashmap)
.map(|x| *x.get("fail").unwrap_or(&0) as u64)
.unwrap(),
.unwrap_or(0),
limit_in_bytes: self
.open_path("memory.swap.max", false)
.and_then(read_i64_from)
Expand Down

0 comments on commit 48545da

Please sign in to comment.