mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-27 05:27:21 +00:00
Add filterProvidersHints function:
- Move initial 'filtering' functionality to generic function filterProvidersHints level policy.go. - Call new function from top level Merge function. - Rename some variables/parameters to reflect changes.
This commit is contained in:
parent
df9b2595f3
commit
45660fd3a2
@ -17,6 +17,7 @@ limitations under the License.
|
|||||||
package topologymanager
|
package topologymanager
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"k8s.io/klog"
|
||||||
"k8s.io/kubernetes/pkg/kubelet/cm/topologymanager/bitmask"
|
"k8s.io/kubernetes/pkg/kubelet/cm/topologymanager/bitmask"
|
||||||
"k8s.io/kubernetes/pkg/kubelet/lifecycle"
|
"k8s.io/kubernetes/pkg/kubelet/lifecycle"
|
||||||
)
|
)
|
||||||
@ -59,6 +60,39 @@ func mergePermutation(numaNodes []int, permutation []TopologyHint) TopologyHint
|
|||||||
return TopologyHint{mergedAffinity, preferred}
|
return TopologyHint{mergedAffinity, preferred}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func filterProvidersHints(providersHints []map[string][]TopologyHint) [][]TopologyHint {
|
||||||
|
// Loop through all hint providers and save an accumulated list of the
|
||||||
|
// hints returned by each hint provider. If no hints are provided, assume
|
||||||
|
// that provider has no preference for topology-aware allocation.
|
||||||
|
var allProviderHints [][]TopologyHint
|
||||||
|
for _, hints := range providersHints {
|
||||||
|
// If hints is nil, insert a single, preferred any-numa hint into allProviderHints.
|
||||||
|
if len(hints) == 0 {
|
||||||
|
klog.Infof("[topologymanager] Hint Provider has no preference for NUMA affinity with any resource")
|
||||||
|
allProviderHints = append(allProviderHints, []TopologyHint{{nil, true}})
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Otherwise, accumulate the hints for each resource type into allProviderHints.
|
||||||
|
for resource := range hints {
|
||||||
|
if hints[resource] == nil {
|
||||||
|
klog.Infof("[topologymanager] Hint Provider has no preference for NUMA affinity with resource '%s'", resource)
|
||||||
|
allProviderHints = append(allProviderHints, []TopologyHint{{nil, true}})
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(hints[resource]) == 0 {
|
||||||
|
klog.Infof("[topologymanager] Hint Provider has no possible NUMA affinities for resource '%s'", resource)
|
||||||
|
allProviderHints = append(allProviderHints, []TopologyHint{{nil, false}})
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
allProviderHints = append(allProviderHints, hints[resource])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return allProviderHints
|
||||||
|
}
|
||||||
|
|
||||||
// Iterate over all permutations of hints in 'allProviderHints [][]TopologyHint'.
|
// Iterate over all permutations of hints in 'allProviderHints [][]TopologyHint'.
|
||||||
//
|
//
|
||||||
// This procedure is implemented as a recursive function over the set of hints
|
// This procedure is implemented as a recursive function over the set of hints
|
||||||
|
@ -17,7 +17,6 @@ limitations under the License.
|
|||||||
package topologymanager
|
package topologymanager
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"k8s.io/klog"
|
|
||||||
"k8s.io/kubernetes/pkg/kubelet/cm/topologymanager/bitmask"
|
"k8s.io/kubernetes/pkg/kubelet/cm/topologymanager/bitmask"
|
||||||
"k8s.io/kubernetes/pkg/kubelet/lifecycle"
|
"k8s.io/kubernetes/pkg/kubelet/lifecycle"
|
||||||
)
|
)
|
||||||
@ -48,54 +47,25 @@ func (p *bestEffortPolicy) canAdmitPodResult(hint *TopologyHint) lifecycle.PodAd
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *bestEffortPolicy) Merge(providersHints []map[string][]TopologyHint) (TopologyHint, lifecycle.PodAdmitResult) {
|
func (p *bestEffortPolicy) Merge(providersHints []map[string][]TopologyHint) (TopologyHint, lifecycle.PodAdmitResult) {
|
||||||
hint := p.mergeProvidersHints(providersHints)
|
filteredProvidersHints := filterProvidersHints(providersHints)
|
||||||
|
hint := p.mergeProvidersHints(filteredProvidersHints)
|
||||||
admit := p.canAdmitPodResult(&hint)
|
admit := p.canAdmitPodResult(&hint)
|
||||||
return hint, admit
|
return hint, admit
|
||||||
}
|
}
|
||||||
|
|
||||||
// Merge the hints from all hint providers to find the best one.
|
// Merge the hints from all hint providers to find the best one.
|
||||||
func (p *bestEffortPolicy) mergeProvidersHints(providersHints []map[string][]TopologyHint) TopologyHint {
|
func (p *bestEffortPolicy) mergeProvidersHints(filteredHints [][]TopologyHint) TopologyHint {
|
||||||
// Set the default affinity as an any-numa affinity containing the list
|
// Set the default affinity as an any-numa affinity containing the list
|
||||||
// of NUMA Nodes available on this machine.
|
// of NUMA Nodes available on this machine.
|
||||||
defaultAffinity, _ := bitmask.NewBitMask(p.numaNodes...)
|
defaultAffinity, _ := bitmask.NewBitMask(p.numaNodes...)
|
||||||
|
|
||||||
// Loop through all hint providers and save an accumulated list of the
|
|
||||||
// hints returned by each hint provider. If no hints are provided, assume
|
|
||||||
// that provider has no preference for topology-aware allocation.
|
|
||||||
var allProviderHints [][]TopologyHint
|
|
||||||
for _, hints := range providersHints {
|
|
||||||
// If hints is nil, insert a single, preferred any-numa hint into allProviderHints.
|
|
||||||
if len(hints) == 0 {
|
|
||||||
klog.Infof("[topologymanager] Hint Provider has no preference for NUMA affinity with any resource")
|
|
||||||
allProviderHints = append(allProviderHints, []TopologyHint{{nil, true}})
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
// Otherwise, accumulate the hints for each resource type into allProviderHints.
|
|
||||||
for resource := range hints {
|
|
||||||
if hints[resource] == nil {
|
|
||||||
klog.Infof("[topologymanager] Hint Provider has no preference for NUMA affinity with resource '%s'", resource)
|
|
||||||
allProviderHints = append(allProviderHints, []TopologyHint{{nil, true}})
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(hints[resource]) == 0 {
|
|
||||||
klog.Infof("[topologymanager] Hint Provider has no possible NUMA affinities for resource '%s'", resource)
|
|
||||||
allProviderHints = append(allProviderHints, []TopologyHint{{nil, false}})
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
allProviderHints = append(allProviderHints, hints[resource])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Iterate over all permutations of hints in 'allProviderHints'. Merge the
|
// Iterate over all permutations of hints in 'allProviderHints'. Merge the
|
||||||
// hints in each permutation by taking the bitwise-and of their affinity masks.
|
// hints in each permutation by taking the bitwise-and of their affinity masks.
|
||||||
// Return the hint with the narrowest NUMANodeAffinity of all merged
|
// Return the hint with the narrowest NUMANodeAffinity of all merged
|
||||||
// permutations that have at least one NUMA ID set. If no merged mask can be
|
// permutations that have at least one NUMA ID set. If no merged mask can be
|
||||||
// found that has at least one NUMA ID set, return the 'defaultAffinity'.
|
// found that has at least one NUMA ID set, return the 'defaultAffinity'.
|
||||||
bestHint := TopologyHint{defaultAffinity, false}
|
bestHint := TopologyHint{defaultAffinity, false}
|
||||||
iterateAllProviderTopologyHints(allProviderHints, func(permutation []TopologyHint) {
|
iterateAllProviderTopologyHints(filteredHints, func(permutation []TopologyHint) {
|
||||||
// Get the NUMANodeAffinity from each hint in the permutation and see if any
|
// Get the NUMANodeAffinity from each hint in the permutation and see if any
|
||||||
// of them encode unpreferred allocations.
|
// of them encode unpreferred allocations.
|
||||||
mergedHint := mergePermutation(p.numaNodes, permutation)
|
mergedHint := mergePermutation(p.numaNodes, permutation)
|
||||||
|
@ -52,7 +52,8 @@ func (p *restrictedPolicy) canAdmitPodResult(hint *TopologyHint) lifecycle.PodAd
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *restrictedPolicy) Merge(providersHints []map[string][]TopologyHint) (TopologyHint, lifecycle.PodAdmitResult) {
|
func (p *restrictedPolicy) Merge(providersHints []map[string][]TopologyHint) (TopologyHint, lifecycle.PodAdmitResult) {
|
||||||
hint := p.mergeProvidersHints(providersHints)
|
filteredHints := filterProvidersHints(providersHints)
|
||||||
|
hint := p.mergeProvidersHints(filteredHints)
|
||||||
admit := p.canAdmitPodResult(&hint)
|
admit := p.canAdmitPodResult(&hint)
|
||||||
return hint, admit
|
return hint, admit
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,6 @@ limitations under the License.
|
|||||||
package topologymanager
|
package topologymanager
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"k8s.io/klog"
|
|
||||||
"k8s.io/kubernetes/pkg/kubelet/cm/topologymanager/bitmask"
|
"k8s.io/kubernetes/pkg/kubelet/cm/topologymanager/bitmask"
|
||||||
"k8s.io/kubernetes/pkg/kubelet/lifecycle"
|
"k8s.io/kubernetes/pkg/kubelet/lifecycle"
|
||||||
)
|
)
|
||||||
@ -72,49 +71,19 @@ func filterSingleNumaHints(allResourcesHints [][]TopologyHint) [][]TopologyHint
|
|||||||
return filteredResourcesHints
|
return filteredResourcesHints
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *singleNumaNodePolicy) mergeProvidersHints(providersHints []map[string][]TopologyHint) TopologyHint {
|
func (p *singleNumaNodePolicy) mergeProvidersHints(filteredHints [][]TopologyHint) TopologyHint {
|
||||||
// Set the default affinity as an any-numa affinity containing the list
|
// Set the default affinity as an any-numa affinity containing the list
|
||||||
// of NUMA Nodes available on this machine.
|
// of NUMA Nodes available on this machine.
|
||||||
defaultAffinity, _ := bitmask.NewBitMask(p.numaNodes...)
|
defaultAffinity, _ := bitmask.NewBitMask(p.numaNodes...)
|
||||||
|
|
||||||
// Loop through all provider hints and save an accumulated list of the
|
|
||||||
// hints returned by each hint provider. If no hints are provided, assume
|
|
||||||
// that provider has no preference for topology-aware allocation.
|
|
||||||
var allProviderHints [][]TopologyHint
|
|
||||||
for _, hints := range providersHints {
|
|
||||||
// If hints is nil, insert a single, preferred any-numa hint into allProviderHints.
|
|
||||||
if len(hints) == 0 {
|
|
||||||
klog.Infof("[topologymanager] Hint Provider has no preference for NUMA affinity with any resource")
|
|
||||||
allProviderHints = append(allProviderHints, []TopologyHint{{nil, true}})
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
// Otherwise, accumulate the hints for each resource type into allProviderHints.
|
|
||||||
for resource := range hints {
|
|
||||||
if hints[resource] == nil {
|
|
||||||
klog.Infof("[topologymanager] Hint Provider has no preference for NUMA affinity with resource '%s'", resource)
|
|
||||||
allProviderHints = append(allProviderHints, []TopologyHint{{nil, true}})
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(hints[resource]) == 0 {
|
|
||||||
klog.Infof("[topologymanager] Hint Provider has no possible NUMA affinities for resource '%s'", resource)
|
|
||||||
allProviderHints = append(allProviderHints, []TopologyHint{{nil, false}})
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
allProviderHints = append(allProviderHints, hints[resource])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Filter to only include don't cares and hints with a single NUMA node.
|
// Filter to only include don't cares and hints with a single NUMA node.
|
||||||
allProviderHints = filterSingleNumaHints(allProviderHints)
|
filteredHints = filterSingleNumaHints(filteredHints)
|
||||||
|
|
||||||
// Set the bestHint to return from this function as {nil false}.
|
// Set the bestHint to return from this function as {nil false}.
|
||||||
// This will only be returned if no better hint can be found when
|
// This will only be returned if no better hint can be found when
|
||||||
// merging hints from each hint provider.
|
// merging hints from each hint provider.
|
||||||
bestHint := TopologyHint{defaultAffinity, false}
|
bestHint := TopologyHint{defaultAffinity, false}
|
||||||
iterateAllProviderTopologyHints(allProviderHints, func(permutation []TopologyHint) {
|
iterateAllProviderTopologyHints(filteredHints, func(permutation []TopologyHint) {
|
||||||
// Get the NUMANodeAffinity from each hint in the permutation and see if any
|
// Get the NUMANodeAffinity from each hint in the permutation and see if any
|
||||||
// of them encode unpreferred allocations.
|
// of them encode unpreferred allocations.
|
||||||
mergedHint := mergePermutation(p.numaNodes, permutation)
|
mergedHint := mergePermutation(p.numaNodes, permutation)
|
||||||
@ -158,7 +127,8 @@ func (p *singleNumaNodePolicy) mergeProvidersHints(providersHints []map[string][
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *singleNumaNodePolicy) Merge(providersHints []map[string][]TopologyHint) (TopologyHint, lifecycle.PodAdmitResult) {
|
func (p *singleNumaNodePolicy) Merge(providersHints []map[string][]TopologyHint) (TopologyHint, lifecycle.PodAdmitResult) {
|
||||||
hint := p.mergeProvidersHints(providersHints)
|
filteredHints := filterProvidersHints(providersHints)
|
||||||
|
hint := p.mergeProvidersHints(filteredHints)
|
||||||
admit := p.canAdmitPodResult(&hint)
|
admit := p.canAdmitPodResult(&hint)
|
||||||
return hint, admit
|
return hint, admit
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user