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:
Kir Kolyshkin 2020-05-20 12:12:44 -07:00
parent d57f5bb286
commit 3c6e8ac4d2
3 changed files with 26 additions and 12 deletions

View File

@ -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)))
} }

View File

@ -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

View File

@ -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