Merge pull request #122022 from sanposhiho/extender-fix

fix: requeue pods rejected by Extenders properly
This commit is contained in:
Kubernetes Prow Robot
2023-12-14 05:10:01 +01:00
committed by GitHub
4 changed files with 68 additions and 3 deletions

View File

@@ -260,6 +260,14 @@ func NewFramework(ctx context.Context, r Registry, profile *config.KubeScheduler
logger: logger,
}
if len(f.extenders) > 0 {
// Extender doesn't support any kind of requeueing feature like EnqueueExtensions in the scheduling framework.
// We register a defaultEnqueueExtension to framework.ExtenderName here.
// And, in the scheduling cycle, when Extenders reject some Nodes and the pod ends up being unschedulable,
// we put framework.ExtenderName to pInfo.UnschedulablePlugins.
f.enqueueExtensions = []framework.EnqueueExtensions{&defaultEnqueueExtension{pluginName: framework.ExtenderName}}
}
if profile == nil {
return f, nil
}