cgroupv2: set mem+swap to max if mem set to max
... and mem+swap is not explicitly set otherwise. This ensures compatibility with cgroupv1 controller which interprets things this way. With this fixed, we can finally enable swap tests for cgroupv2. Signed-off-by: Kir Kolyshkin <kolyshkin@gmail.com>
This commit is contained in:
parent
d57f5bb286
commit
3c6e8ac4d2
|
@ -57,12 +57,12 @@ func genV2ResourcesProperties(c *configs.Cgroup) ([]systemdDbus.Property, error)
|
||||||
properties = append(properties,
|
properties = append(properties,
|
||||||
newProp("MemoryLow", uint64(c.Resources.MemoryReservation)))
|
newProp("MemoryLow", uint64(c.Resources.MemoryReservation)))
|
||||||
}
|
}
|
||||||
// swap is set
|
|
||||||
if c.Resources.MemorySwap != 0 {
|
swap, err := cgroups.ConvertMemorySwapToCgroupV2Value(c.Resources.MemorySwap, c.Resources.Memory)
|
||||||
swap, err := cgroups.ConvertMemorySwapToCgroupV2Value(c.Resources.MemorySwap, c.Resources.Memory)
|
if err != nil {
|
||||||
if err != nil {
|
return nil, err
|
||||||
return nil, err
|
}
|
||||||
}
|
if swap != 0 {
|
||||||
properties = append(properties,
|
properties = append(properties,
|
||||||
newProp("MemorySwapMax", uint64(swap)))
|
newProp("MemorySwapMax", uint64(swap)))
|
||||||
}
|
}
|
||||||
|
|
|
@ -612,6 +612,12 @@ func ConvertCPUQuotaCPUPeriodToCgroupV2Value(quota int64, period uint64) string
|
||||||
// for use by cgroup v2 drivers. A conversion is needed since Resources.MemorySwap
|
// for use by cgroup v2 drivers. A conversion is needed since Resources.MemorySwap
|
||||||
// is defined as memory+swap combined, while in cgroup v2 swap is a separate value.
|
// is defined as memory+swap combined, while in cgroup v2 swap is a separate value.
|
||||||
func ConvertMemorySwapToCgroupV2Value(memorySwap, memory int64) (int64, error) {
|
func ConvertMemorySwapToCgroupV2Value(memorySwap, memory int64) (int64, error) {
|
||||||
|
// for compatibility with cgroup1 controller, set swap to unlimited in
|
||||||
|
// case the memory is set to unlimited, and swap is not explicitly set,
|
||||||
|
// treating the request as "set both memory and swap to unlimited".
|
||||||
|
if memory == -1 && memorySwap == 0 {
|
||||||
|
return -1, nil
|
||||||
|
}
|
||||||
if memorySwap == -1 || memorySwap == 0 {
|
if memorySwap == -1 || memorySwap == 0 {
|
||||||
// -1 is "max", 0 is "unset", so treat as is
|
// -1 is "max", 0 is "unset", so treat as is
|
||||||
return memorySwap, nil
|
return memorySwap, nil
|
||||||
|
|
|
@ -80,8 +80,7 @@ EOF
|
||||||
SD_MEM_SWAP="MemorySwapMax"
|
SD_MEM_SWAP="MemorySwapMax"
|
||||||
SYSTEM_MEM="max"
|
SYSTEM_MEM="max"
|
||||||
SYSTEM_MEM_SWAP="max"
|
SYSTEM_MEM_SWAP="max"
|
||||||
# checking swap is currently disabled for v2
|
CGROUP_MEMORY=$CGROUP_PATH
|
||||||
#CGROUP_MEMORY=$CGROUP_PATH
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
SD_UNLIMITED="infinity"
|
SD_UNLIMITED="infinity"
|
||||||
|
@ -135,10 +134,19 @@ EOF
|
||||||
check_systemd_value "$SD_MEM_SWAP" $SD_UNLIMITED
|
check_systemd_value "$SD_MEM_SWAP" $SD_UNLIMITED
|
||||||
|
|
||||||
# update memory swap
|
# update memory swap
|
||||||
runc update test_update --memory-swap 96468992
|
if [ "$CGROUP_UNIFIED" = "yes" ]; then
|
||||||
[ "$status" -eq 0 ]
|
# for cgroupv2, memory and swap can only be set together
|
||||||
check_cgroup_value "$MEM_SWAP" 96468992
|
runc update test_update --memory 52428800 --memory-swap 96468992
|
||||||
check_systemd_value "$SD_MEM_SWAP" 96468992
|
[ "$status" -eq 0 ]
|
||||||
|
# for cgroupv2, swap is a separate limit (it does not include mem)
|
||||||
|
check_cgroup_value "$MEM_SWAP" $((96468992-52428800))
|
||||||
|
check_systemd_value "$SD_MEM_SWAP" $((96468992-52428800))
|
||||||
|
else
|
||||||
|
runc update test_update --memory-swap 96468992
|
||||||
|
[ "$status" -eq 0 ]
|
||||||
|
check_cgroup_value "$MEM_SWAP" 96468992
|
||||||
|
check_systemd_value "$SD_MEM_SWAP" 96468992
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# try to remove memory limit
|
# try to remove memory limit
|
||||||
|
|
Loading…
Reference in New Issue