Skip to content

Commit

Permalink
set min reclaim pool size for multi region
Browse files Browse the repository at this point in the history
  • Loading branch information
yadzhang committed Jan 13, 2025
1 parent f3d81a4 commit 23eb7fd
Showing 1 changed file with 31 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ package provisionassembler
import (
"fmt"
"math"
"os"
"strconv"
"time"

"k8s.io/klog/v2"
Expand All @@ -35,6 +37,18 @@ import (
"github.com/kubewharf/katalyst-core/pkg/util/machine"
)

var (
defaultMinReclaimPoolSize = 8
)

func init() {
if value := os.Getenv("MIN_RECLAIM_POOLSIZE"); value == "" {
if size, err := strconv.Atoi(value); err == nil && size > defaultMinReclaimPoolSize {
defaultMinReclaimPoolSize = size
}
}
}

type ProvisionAssemblerCommon struct {
conf *config.Configuration
regionMap *map[string]region.QoSRegion
Expand Down Expand Up @@ -293,6 +307,23 @@ func (pa *ProvisionAssemblerCommon) AssembleProvision() (types.InternalCPUCalcul
}
}
reclaimPoolSizeOfNonBindingNUMAs = general.SumUpMapValues(sharedOverlapReclaimSize)

if reclaimPoolSizeOfNonBindingNUMAs < defaultMinReclaimPoolSize {
newSharedOverlapReclaimSize, err := regulateOverlapReclaimPoolSize(sharePoolSizes, defaultMinReclaimPoolSize)
if err != nil {
klog.ErrorS(err, "calculate pool size is too low, fall back to ratio policy failed",
"share pool size", sharePoolSizes,
"min reclaim pool size", defaultMinReclaimPoolSize,
"old reclaim pool", sharedOverlapReclaimSize)
} else {
klog.InfoS("calculate pool size is too low, fall back to ratio policy",
"share pool size", sharePoolSizes,
"min reclaim pool size", defaultMinReclaimPoolSize,
"old reclaim pool", sharedOverlapReclaimSize, "new reclaim pool", newSharedOverlapReclaimSize)
sharedOverlapReclaimSize = newSharedOverlapReclaimSize
reclaimPoolSizeOfNonBindingNUMAs = general.SumUpMapValues(sharedOverlapReclaimSize)
}
}
}

for overlapPoolName, size := range sharedOverlapReclaimSize {
Expand Down

0 comments on commit 23eb7fd

Please sign in to comment.