mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-31 05:40:42 +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
 | |
| }
 |