Documentation ¶
Index ¶
Constants ¶
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:
- 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)
- 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
- 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
- defining a new service account for a new controller (old controllers may have inconsistent service accounts to stay backwards compatible)
- anywhere these controllers are used outside of this module (kube-controller-manager, cloud-provider sample)
Variables ¶
This section is empty.
Functions ¶
func CCMControllerAliases ¶
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.