names

package
v0.28.14 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 11, 2024 License: Apache-2.0 Imports: 0 Imported by: 49

Documentation

Index

Constants

View Source
const (
	CloudNodeController          = "cloud-node-controller"
	ServiceLBController          = "service-lb-controller"
	NodeRouteController          = "node-route-controller"
	CloudNodeLifecycleController = "cloud-node-lifecycle-controller"
)

Canonical controller names

NAMING CONVENTIONS 1. naming should be consistent across the controllers 2. use of shortcuts should be avoided, unless they are well-known non-Kubernetes shortcuts 3. Kubernetes' resources should be written together without a hyphen ("-")

CHANGE POLICY The controller names should be treated as IDs. They can only be changed if absolutely necessary. For example if an inappropriate name was chosen in the past, or if the scope of the controller changes. When a name is changed, the old name should be aliased in CCMControllerAliases, while preserving all old aliases. This is done to achieve backwards compatibility

USE CASES The following places should use the controller name constants, when:

  1. registering a controller in app.DefaultInitFuncConstructors or sample main.controllerInitializers: 1.1. disabling a controller by default in app.ControllersDisabledByDefault 1.2. checking if IsControllerEnabled 1.3. defining an alias in CCMControllerAliases (for backwards compatibility only)
  2. used anywhere inside the controller itself: 2.1. [TODO] logger component should be configured with the controller name by calling LoggerWithName 2.2. [TODO] logging should use a canonical controller name when referencing a controller (Eg. Starting X, Shutting down X) 2.3. [TODO] emitted events should have an EventSource.Component set to the controller name (usually when initializing an EventRecorder) 2.4. [TODO] registering ControllerManagerMetrics with ControllerStarted and ControllerStopped 2.5. [TODO] calling WaitForNamedCacheSync
  3. defining controller options for "--help" command or generated documentation 3.1. controller name should be used to create a pflag.FlagSet when registering controller options (the name is rendered in a controller flag group header) 3.2. when defined flag's help mentions a controller name
  4. defining a new service account for a new controller (old controllers may have inconsistent service accounts to stay backwards compatible)
  5. anywhere these controllers are used outside of this module (kube-controller-manager, cloud-provider sample)

Variables

This section is empty.

Functions

func CCMControllerAliases

func CCMControllerAliases() map[string]string

CCMControllerAliases returns a mapping of aliases to canonical controller names

These aliases ensure backwards compatibility and should never be removed! Only addition of new aliases is allowed, and only when a canonical name is changed (please see CHANGE POLICY of controller names)

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL