fix: requeue pods rejected by Extenders properly

This commit is contained in:
Kensei Nakada
2023-11-23 12:17:47 +00:00
parent 1f07da7575
commit 468e2dac81
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
}