mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-04 04:08:16 +00:00 
			
		
		
		
	Refactor the kube-scheduler configuration API, command setup, and server setup according to the guidelines established in #32215 and using the kube-proxy refactor (#34727) as a model of a well factored component adhering to said guidelines. * Config API: clarify meaning and use of algorithm source by replacing modality derived from bools and string emptiness checks with an explicit AlgorithmSource type hierarchy. * Config API: consolidate client connection config with common structs. * Config API: split and simplify healthz/metrics server configuration. * Config API: clarify leader election configuration. * Config API: improve defaulting. * CLI: deprecate all flags except `--config`. * CLI: port all flags to new config API. * CLI: refactor to match kube-proxy Cobra command style. * Server: refactor away configurator.go to clarify application wiring. * Server: refactor to more clearly separate wiring/setup from running. Fixes #52428.
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2015 The Kubernetes Authors.
 | 
						|
 | 
						|
Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
you may not use this file except in compliance with the License.
 | 
						|
You may obtain a copy of the License at
 | 
						|
 | 
						|
    http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 | 
						|
Unless required by applicable law or agreed to in writing, software
 | 
						|
distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
See the License for the specific language governing permissions and
 | 
						|
limitations under the License.
 | 
						|
*/
 | 
						|
 | 
						|
package main
 | 
						|
 | 
						|
import (
 | 
						|
	"flag"
 | 
						|
 | 
						|
	"k8s.io/apiserver/pkg/server/healthz"
 | 
						|
	"k8s.io/kubernetes/plugin/cmd/kube-scheduler/app"
 | 
						|
)
 | 
						|
 | 
						|
// NewScheduler creates a new hyperkube Server object that includes the
 | 
						|
// description and flags.
 | 
						|
func NewScheduler() *Server {
 | 
						|
	healthz.DefaultHealthz()
 | 
						|
 | 
						|
	command := app.NewSchedulerCommand()
 | 
						|
 | 
						|
	hks := Server{
 | 
						|
		name:            "scheduler",
 | 
						|
		AlternativeName: "kube-scheduler",
 | 
						|
		SimpleUsage:     "scheduler",
 | 
						|
		Long:            command.Long,
 | 
						|
	}
 | 
						|
 | 
						|
	serverFlags := hks.Flags()
 | 
						|
	serverFlags.AddFlagSet(command.Flags())
 | 
						|
 | 
						|
	// FIXME this is here because hyperkube does its own flag parsing, and we need
 | 
						|
	// the command to know about the go flag set. Remove this once hyperkube is
 | 
						|
	// refactored to use cobra throughout.
 | 
						|
	command.Flags().AddGoFlagSet(flag.CommandLine)
 | 
						|
 | 
						|
	hks.Run = func(_ *Server, args []string, stopCh <-chan struct{}) error {
 | 
						|
		command.SetArgs(args)
 | 
						|
		return command.Execute()
 | 
						|
	}
 | 
						|
 | 
						|
	return &hks
 | 
						|
}
 |