kube-controller-manager Configuration (v1alpha1)
ControllerLeaderConfiguration
ControllerLeaderConfiguration provides the configuration for a migrating leader lock.
GenericControllerManagerConfiguration
Appears in:
GenericControllerManagerConfiguration holds configuration for a generic controller-manager.
Field | Description |
---|---|
Port [Required]int32 | port is the port that the controller-manager’s http service runs on. |
Address [Required]string | address is the IP address to serve on (set to 0.0.0.0 for all interfaces). |
MinResyncPeriod [Required]meta/v1.Duration | minResyncPeriod is the resync period in reflectors; will be random between minResyncPeriod and 2minResyncPeriod. |
ClientConnection [Required] | ClientConnection specifies the kubeconfig file and client connection settings for the proxy server to use when communicating with the apiserver. |
ControllerStartInterval [Required]meta/v1.Duration | How long to wait between starting controller managers |
LeaderElection [Required] | leaderElection defines the configuration of leader election client. |
Controllers [Required][]string | Controllers is the list of controllers to enable or disable ‘‘ means “all enabled by default controllers” ‘foo’ means “enable ‘foo’” ‘-foo’ means “disable ‘foo’” first item for a particular name wins |
Debugging [Required]DebuggingConfiguration | DebuggingConfiguration holds configuration for Debugging related features. |
LeaderMigrationEnabled [Required]bool | LeaderMigrationEnabled indicates whether Leader Migration should be enabled for the controller manager. |
LeaderMigration [Required] | LeaderMigration holds the configuration for Leader Migration. |
LeaderMigrationConfiguration
Appears in:
LeaderMigrationConfiguration provides versioned configuration for all migrating leader locks.
Field | Description |
---|---|
leaderName [Required]string | LeaderName is the name of the leader election resource that protects the migration E.g. 1-20-KCM-to-1-21-CCM |
resourceLock [Required]string | ResourceLock indicates the resource object type that will be used to lock Should be “leases” or “endpoints” |
controllerLeaders [Required][]ControllerLeaderConfiguration | ControllerLeaders contains a list of migrating leader lock configurations |
KubeControllerManagerConfiguration
KubeControllerManagerConfiguration contains elements describing kube-controller manager.
Field | Description |
---|---|
apiVersion string | kubecontrollermanager.config.k8s.io/v1alpha1 |
kind string | KubeControllerManagerConfiguration |
Generic [Required]GenericControllerManagerConfiguration | Generic holds configuration for a generic controller-manager |
KubeCloudShared [Required] | KubeCloudSharedConfiguration holds configuration for shared related features both in cloud controller manager and kube-controller manager. |
AttachDetachController [Required]AttachDetachControllerConfiguration | AttachDetachControllerConfiguration holds configuration for AttachDetachController related features. |
CSRSigningController [Required] | CSRSigningControllerConfiguration holds configuration for CSRSigningController related features. |
DaemonSetController [Required]DaemonSetControllerConfiguration | DaemonSetControllerConfiguration holds configuration for DaemonSetController related features. |
DeploymentController [Required] | DeploymentControllerConfiguration holds configuration for DeploymentController related features. |
StatefulSetController [Required]StatefulSetControllerConfiguration | StatefulSetControllerConfiguration holds configuration for StatefulSetController related features. |
DeprecatedController [Required] | DeprecatedControllerConfiguration holds configuration for some deprecated features. |
EndpointController [Required]EndpointControllerConfiguration | EndpointControllerConfiguration holds configuration for EndpointController related features. |
EndpointSliceController [Required] | EndpointSliceControllerConfiguration holds configuration for EndpointSliceController related features. |
EndpointSliceMirroringController [Required]EndpointSliceMirroringControllerConfiguration | EndpointSliceMirroringControllerConfiguration holds configuration for EndpointSliceMirroringController related features. |
EphemeralVolumeController [Required] | EphemeralVolumeControllerConfiguration holds configuration for EphemeralVolumeController related features. |
GarbageCollectorController [Required]GarbageCollectorControllerConfiguration | GarbageCollectorControllerConfiguration holds configuration for GarbageCollectorController related features. |
HPAController [Required] | HPAControllerConfiguration holds configuration for HPAController related features. |
JobController [Required]JobControllerConfiguration | JobControllerConfiguration holds configuration for JobController related features. |
CronJobController [Required] | CronJobControllerConfiguration holds configuration for CronJobController related features. |
NamespaceController [Required]NamespaceControllerConfiguration | NamespaceControllerConfiguration holds configuration for NamespaceController related features. NamespaceControllerConfiguration holds configuration for NamespaceController related features. |
NodeIPAMController [Required] | NodeIPAMControllerConfiguration holds configuration for NodeIPAMController related features. |
NodeLifecycleController [Required]NodeLifecycleControllerConfiguration | NodeLifecycleControllerConfiguration holds configuration for NodeLifecycleController related features. |
PersistentVolumeBinderController [Required] | PersistentVolumeBinderControllerConfiguration holds configuration for PersistentVolumeBinderController related features. |
PodGCController [Required]PodGCControllerConfiguration | PodGCControllerConfiguration holds configuration for PodGCController related features. |
ReplicaSetController [Required] | ReplicaSetControllerConfiguration holds configuration for ReplicaSet related features. |
ReplicationController [Required]ReplicationControllerConfiguration | ReplicationControllerConfiguration holds configuration for ReplicationController related features. |
ResourceQuotaController [Required] | ResourceQuotaControllerConfiguration holds configuration for ResourceQuotaController related features. |
SAController [Required]SAControllerConfiguration | SAControllerConfiguration holds configuration for ServiceAccountController related features. |
ServiceController [Required] | ServiceControllerConfiguration holds configuration for ServiceController related features. |
TTLAfterFinishedController [Required]TTLAfterFinishedControllerConfiguration | TTLAfterFinishedControllerConfiguration holds configuration for TTLAfterFinishedController related features. |
AttachDetachControllerConfiguration
Appears in:
AttachDetachControllerConfiguration contains elements describing AttachDetachController.
Field | Description |
---|---|
DisableAttachDetachReconcilerSync [Required] | Reconciler runs a periodic loop to reconcile the desired state of the with the actual state of the world by triggering attach detach operations. This flag enables or disables reconcile. Is false by default, and thus enabled. |
ReconcilerSyncLoopPeriod [Required] | ReconcilerSyncLoopPeriod is the amount of time the reconciler sync states loop wait between successive executions. Is set to 5 sec by default. |
CSRSigningConfiguration
Appears in:
CSRSigningConfiguration holds information about a particular CSR signer
Field | Description |
---|---|
CertFile [Required]string | certFile is the filename containing a PEM-encoded X509 CA certificate used to issue certificates |
KeyFile [Required]string | keyFile is the filename containing a PEM-encoded RSA or ECDSA private key used to issue certificates |
CSRSigningControllerConfiguration
Appears in:
CSRSigningControllerConfiguration contains elements describing CSRSigningController.
Field | Description |
---|---|
ClusterSigningCertFile [Required]string | clusterSigningCertFile is the filename containing a PEM-encoded X509 CA certificate used to issue cluster-scoped certificates |
ClusterSigningKeyFile [Required]string | clusterSigningCertFile is the filename containing a PEM-encoded RSA or ECDSA private key used to issue cluster-scoped certificates |
KubeletServingSignerConfiguration [Required]CSRSigningConfiguration | kubeletServingSignerConfiguration holds the certificate and key used to issue certificates for the kubernetes.io/kubelet-serving signer |
KubeletClientSignerConfiguration [Required] | kubeletClientSignerConfiguration holds the certificate and key used to issue certificates for the kubernetes.io/kube-apiserver-client-kubelet |
KubeAPIServerClientSignerConfiguration [Required]CSRSigningConfiguration | kubeAPIServerClientSignerConfiguration holds the certificate and key used to issue certificates for the kubernetes.io/kube-apiserver-client |
LegacyUnknownSignerConfiguration [Required] | legacyUnknownSignerConfiguration holds the certificate and key used to issue certificates for the kubernetes.io/legacy-unknown |
ClusterSigningDuration [Required]meta/v1.Duration | clusterSigningDuration is the max length of duration signed certificates will be given. Individual CSRs may request shorter certs by setting spec.expirationSeconds. |
CronJobControllerConfiguration
Appears in:
CronJobControllerConfiguration contains elements describing CrongJob2Controller.
Field | Description |
---|---|
ConcurrentCronJobSyncs [Required]int32 | concurrentCronJobSyncs is the number of job objects that are allowed to sync concurrently. Larger number = more responsive jobs, but more CPU (and network) load. |
DaemonSetControllerConfiguration
DaemonSetControllerConfiguration contains elements describing DaemonSetController.
Field | Description |
---|---|
ConcurrentDaemonSetSyncs [Required]int32 | concurrentDaemonSetSyncs is the number of daemonset objects that are allowed to sync concurrently. Larger number = more responsive daemonset, but more CPU (and network) load. |
DeploymentControllerConfiguration
Appears in:
DeploymentControllerConfiguration contains elements describing DeploymentController.
Field | Description |
---|---|
ConcurrentDeploymentSyncs [Required]int32 | concurrentDeploymentSyncs is the number of deployment objects that are allowed to sync concurrently. Larger number = more responsive deployments, but more CPU (and network) load. |
DeprecatedControllerConfiguration
Appears in:
DeprecatedControllerConfiguration contains elements be deprecated.
Appears in:
EndpointControllerConfiguration contains elements describing EndpointController.
Field | Description |
---|---|
ConcurrentEndpointSyncs [Required]int32 | concurrentEndpointSyncs is the number of endpoint syncing operations that will be done concurrently. Larger number = faster endpoint updating, but more CPU (and network) load. |
EndpointUpdatesBatchPeriod [Required]meta/v1.Duration | EndpointUpdatesBatchPeriod describes the length of endpoint updates batching period. Processing of pod changes will be delayed by this duration to join them with potential upcoming updates and reduce the overall number of endpoints updates. |
EndpointSliceControllerConfiguration
Appears in:
EndpointSliceControllerConfiguration contains elements describing EndpointSliceController.
EndpointSliceMirroringControllerConfiguration
Appears in:
EndpointSliceMirroringControllerConfiguration contains elements describing EndpointSliceMirroringController.
Field | Description |
---|---|
MirroringConcurrentServiceEndpointSyncs [Required]int32 | mirroringConcurrentServiceEndpointSyncs is the number of service endpoint syncing operations that will be done concurrently. Larger number = faster endpoint slice updating, but more CPU (and network) load. |
MirroringMaxEndpointsPerSubset [Required]int32 | mirroringMaxEndpointsPerSubset is the maximum number of endpoints that will be mirrored to an EndpointSlice for an EndpointSubset. |
MirroringEndpointUpdatesBatchPeriod [Required] | mirroringEndpointUpdatesBatchPeriod can be used to batch EndpointSlice updates. All updates triggered by EndpointSlice changes will be delayed by up to ‘mirroringEndpointUpdatesBatchPeriod’. If other addresses in the same Endpoints resource change in that period, they will be batched to a single EndpointSlice update. Default 0 value means that each Endpoints update triggers an EndpointSlice update. |
EphemeralVolumeControllerConfiguration
Appears in:
EphemeralVolumeControllerConfiguration contains elements describing EphemeralVolumeController.
Field | Description |
---|---|
ConcurrentEphemeralVolumeSyncs [Required]int32 | ConcurrentEphemeralVolumeSyncseSyncs is the number of ephemeral volume syncing operations that will be done concurrently. Larger number = faster ephemeral volume updating, but more CPU (and network) load. |
GarbageCollectorControllerConfiguration
Appears in:
GarbageCollectorControllerConfiguration contains elements describing GarbageCollectorController.
Field | Description |
---|---|
EnableGarbageCollector [Required]bool | enables the generic garbage collector. MUST be synced with the corresponding flag of the kube-apiserver. WARNING: the generic garbage collector is an alpha feature. |
ConcurrentGCSyncs [Required]int32 | concurrentGCSyncs is the number of garbage collector workers that are allowed to sync concurrently. |
GCIgnoredResources [Required][]GroupResource | gcIgnoredResources is the list of GroupResources that garbage collection should ignore. |
GroupResource
Appears in:
GroupResource describes an group resource.
Field | Description |
---|---|
Group [Required]string | group is the group portion of the GroupResource. |
Resource [Required]string | resource is the resource portion of the GroupResource. |
HPAControllerConfiguration
Appears in:
HPAControllerConfiguration contains elements describing HPAController.
Field | Description |
---|---|
ConcurrentHorizontalPodAutoscalerSyncs [Required]int32 | ConcurrentHorizontalPodAutoscalerSyncs is the number of HPA objects that are allowed to sync concurrently. Larger number = more responsive HPA processing, but more CPU (and network) load. |
HorizontalPodAutoscalerSyncPeriod [Required] | HorizontalPodAutoscalerSyncPeriod is the period for syncing the number of pods in horizontal pod autoscaler. |
HorizontalPodAutoscalerUpscaleForbiddenWindow [Required]meta/v1.Duration | HorizontalPodAutoscalerUpscaleForbiddenWindow is a period after which next upscale allowed. |
HorizontalPodAutoscalerDownscaleStabilizationWindow [Required] | HorizontalPodAutoscalerDowncaleStabilizationWindow is a period for which autoscaler will look backwards and not scale down below any recommendation it made during that period. |
HorizontalPodAutoscalerDownscaleForbiddenWindow [Required]meta/v1.Duration | HorizontalPodAutoscalerDownscaleForbiddenWindow is a period after which next downscale allowed. |
HorizontalPodAutoscalerTolerance [Required]float64 | HorizontalPodAutoscalerTolerance is the tolerance for when resource usage suggests upscaling/downscaling |
HorizontalPodAutoscalerCPUInitializationPeriod [Required] | HorizontalPodAutoscalerCPUInitializationPeriod is the period after pod start when CPU samples might be skipped. |
HorizontalPodAutoscalerInitialReadinessDelay [Required]meta/v1.Duration | HorizontalPodAutoscalerInitialReadinessDelay is period after pod start during which readiness changes are treated as readiness being set for the first time. The only effect of this is that HPA will disregard CPU samples from unready pods that had last readiness change during that period. |
JobControllerConfiguration
Appears in:
JobControllerConfiguration contains elements describing JobController.
Field | Description |
---|---|
ConcurrentJobSyncs [Required]int32 | concurrentJobSyncs is the number of job objects that are allowed to sync concurrently. Larger number = more responsive jobs, but more CPU (and network) load. |
NamespaceControllerConfiguration
Appears in:
NamespaceControllerConfiguration contains elements describing NamespaceController.
Field | Description |
---|---|
NamespaceSyncPeriod [Required] | namespaceSyncPeriod is the period for syncing namespace life-cycle updates. |
ConcurrentNamespaceSyncs [Required]int32 | concurrentNamespaceSyncs is the number of namespace objects that are allowed to sync concurrently. |
NodeIPAMControllerConfiguration
Appears in:
NodeIPAMControllerConfiguration contains elements describing NodeIpamController.
Field | Description |
---|---|
ServiceCIDR [Required]string | serviceCIDR is CIDR Range for Services in cluster. |
SecondaryServiceCIDR [Required]string | secondaryServiceCIDR is CIDR Range for Services in cluster. This is used in dual stack clusters. SecondaryServiceCIDR must be of different IP family than ServiceCIDR |
NodeCIDRMaskSize [Required]int32 | NodeCIDRMaskSize is the mask size for node cidr in cluster. |
NodeCIDRMaskSizeIPv4 [Required]int32 | NodeCIDRMaskSizeIPv4 is the mask size for node cidr in dual-stack cluster. |
NodeCIDRMaskSizeIPv6 [Required]int32 | NodeCIDRMaskSizeIPv6 is the mask size for node cidr in dual-stack cluster. |
NodeLifecycleControllerConfiguration
Appears in:
NodeLifecycleControllerConfiguration contains elements describing NodeLifecycleController.
Field | Description |
---|---|
EnableTaintManager [Required]bool | If set to true enables NoExecute Taints and will evict all not-tolerating Pod running on Nodes tainted with this kind of Taints. |
NodeEvictionRate [Required]float32 | nodeEvictionRate is the number of nodes per second on which pods are deleted in case of node failure when a zone is healthy |
SecondaryNodeEvictionRate [Required]float32 | secondaryNodeEvictionRate is the number of nodes per second on which pods are deleted in case of node failure when a zone is unhealthy |
NodeStartupGracePeriod [Required]meta/v1.Duration | nodeStartupGracePeriod is the amount of time which we allow starting a node to be unresponsive before marking it unhealthy. |
NodeMonitorGracePeriod [Required] | nodeMontiorGracePeriod is the amount of time which we allow a running node to be unresponsive before marking it unhealthy. Must be N times more than kubelet’s nodeStatusUpdateFrequency, where N means number of retries allowed for kubelet to post node status. |
PodEvictionTimeout [Required]meta/v1.Duration | podEvictionTimeout is the grace period for deleting pods on failed nodes. |
[Required]int32 | secondaryNodeEvictionRate is implicitly overridden to 0 for clusters smaller than or equal to largeClusterSizeThreshold |
UnhealthyZoneThreshold [Required]float32 | Zone is treated as unhealthy in nodeEvictionRate and secondaryNodeEvictionRate when at least unhealthyZoneThreshold (no less than 3) of Nodes in the zone are NotReady |
PersistentVolumeBinderControllerConfiguration
Appears in:
PersistentVolumeBinderControllerConfiguration contains elements describing PersistentVolumeBinderController.
Field | Description |
---|---|
PVClaimBinderSyncPeriod [Required] | pvClaimBinderSyncPeriod is the period for syncing persistent volumes and persistent volume claims. |
VolumeConfiguration [Required]VolumeConfiguration | |
VolumeHostCIDRDenylist [Required][]string | VolumeHostCIDRDenylist is a list of CIDRs that should not be reachable by the controller from plugins. |
VolumeHostAllowLocalLoopback [Required]bool | VolumeHostAllowLocalLoopback indicates if local loopback hosts (127.0.0.1, etc) should be allowed from plugins. |
Appears in:
PersistentVolumeRecyclerConfiguration contains elements describing persistent volume plugins.
PodGCControllerConfiguration
Appears in:
PodGCControllerConfiguration contains elements describing PodGCController.
Field | Description |
---|---|
TerminatedPodGCThreshold [Required]int32 | terminatedPodGCThreshold is the number of terminated pods that can exist before the terminated pod garbage collector starts deleting terminated pods. If <= 0, the terminated pod garbage collector is disabled. |
ReplicaSetControllerConfiguration
Appears in:
ReplicaSetControllerConfiguration contains elements describing ReplicaSetController.
Field | Description |
---|---|
ConcurrentRSSyncs [Required]int32 | concurrentRSSyncs is the number of replica sets that are allowed to sync concurrently. Larger number = more responsive replica management, but more CPU (and network) load. |
ReplicationControllerConfiguration
Appears in:
ReplicationControllerConfiguration contains elements describing ReplicationController.
Field | Description |
---|---|
ConcurrentRCSyncs [Required]int32 | concurrentRCSyncs is the number of replication controllers that are allowed to sync concurrently. Larger number = more responsive replica management, but more CPU (and network) load. |
ResourceQuotaControllerConfiguration
Appears in:
ResourceQuotaControllerConfiguration contains elements describing ResourceQuotaController.
Field | Description |
---|---|
ResourceQuotaSyncPeriod [Required] | resourceQuotaSyncPeriod is the period for syncing quota usage status in the system. |
ConcurrentResourceQuotaSyncs [Required]int32 | concurrentResourceQuotaSyncs is the number of resource quotas that are allowed to sync concurrently. Larger number = more responsive quota management, but more CPU (and network) load. |
SAControllerConfiguration
Appears in:
SAControllerConfiguration contains elements describing ServiceAccountController.
Field | Description |
---|---|
ServiceAccountKeyFile [Required]string | serviceAccountKeyFile is the filename containing a PEM-encoded private RSA key used to sign service account tokens. |
ConcurrentSATokenSyncs [Required]int32 | concurrentSATokenSyncs is the number of service account token syncing operations that will be done concurrently. |
RootCAFile [Required]string | rootCAFile is the root certificate authority will be included in service account’s token secret. This must be a valid PEM-encoded CA bundle. |
StatefulSetControllerConfiguration
Appears in:
StatefulSetControllerConfiguration contains elements describing StatefulSetController.
Field | Description |
---|---|
ConcurrentStatefulSetSyncs [Required]int32 | concurrentStatefulSetSyncs is the number of statefulset objects that are allowed to sync concurrently. Larger number = more responsive statefulsets, but more CPU (and network) load. |
TTLAfterFinishedControllerConfiguration
Appears in:
TTLAfterFinishedControllerConfiguration contains elements describing TTLAfterFinishedController.
Field | Description |
---|---|
ConcurrentTTLSyncs [Required]int32 | concurrentTTLSyncs is the number of TTL-after-finished collector workers that are allowed to sync concurrently. |
VolumeConfiguration
Appears in:
VolumeConfiguration contains all enumerated flags meant to configure all volume plugins. From this config, the controller-manager binary will create many instances of volume.VolumeConfig, each containing only the configuration needed for that plugin which are then passed to the appropriate plugin. The ControllerManager binary is the only part of the code which knows what plugins are supported and which flags correspond to each plugin.
Field | Description |
---|---|
EnableHostPathProvisioning [Required]bool | enableHostPathProvisioning enables HostPath PV provisioning when running without a cloud provider. This allows testing and development of provisioning features. HostPath provisioning is not supported in any way, won’t work in a multi-node cluster, and should not be used for anything other than testing or development. |
EnableDynamicProvisioning [Required]bool | enableDynamicProvisioning enables the provisioning of volumes when running within an environment that supports dynamic provisioning. Defaults to true. |
PersistentVolumeRecyclerConfiguration [Required]PersistentVolumeRecyclerConfiguration | persistentVolumeRecyclerConfiguration holds configuration for persistent volume plugins. |
FlexVolumePluginDir [Required]string | volumePluginDir is the full path of the directory in which the flex volume plugin should search for additional third party volume plugins |
ServiceControllerConfiguration
Appears in:
ServiceControllerConfiguration contains elements describing ServiceController.
Field | Description |
---|---|
ConcurrentServiceSyncs [Required]int32 | concurrentServiceSyncs is the number of services that are allowed to sync concurrently. Larger number = more responsive service management, but more CPU (and network) load. |
CloudControllerManagerConfiguration
Field | Description |
---|---|
apiVersion string | cloudcontrollermanager.config.k8s.io/v1alpha1 |
kind string | CloudControllerManagerConfiguration |
Generic [Required] | Generic holds configuration for a generic controller-manager |
KubeCloudShared [Required]KubeCloudSharedConfiguration | KubeCloudSharedConfiguration holds configuration for shared related features both in cloud controller manager and kube-controller manager. |
ServiceController [Required] | ServiceControllerConfiguration holds configuration for ServiceController related features. |
NodeStatusUpdateFrequency [Required]meta/v1.Duration | NodeStatusUpdateFrequency is the frequency at which the controller updates nodes’ status |
CloudProviderConfiguration
Appears in:
CloudProviderConfiguration contains basically elements about cloud provider.
Appears in:
KubeCloudSharedConfiguration contains elements shared by both kube-controller manager and cloud-controller manager, but not genericconfig.
Field | Description |
---|---|
CloudProvider [Required] | CloudProviderConfiguration holds configuration for CloudProvider related features. |
ExternalCloudVolumePlugin [Required]string | externalCloudVolumePlugin specifies the plugin to use when cloudProvider is “external”. It is currently used by the in repo cloud providers to handle node and volume control in the KCM. |
UseServiceAccountCredentials [Required]bool | useServiceAccountCredentials indicates whether controllers should be run with individual service account credentials. |
AllowUntaggedCloud [Required]bool | run with untagged cloud instances |
RouteReconciliationPeriod [Required]meta/v1.Duration | routeReconciliationPeriod is the period for reconciling routes created for Nodes by cloud provider.. |
NodeMonitorPeriod [Required] | nodeMonitorPeriod is the period for syncing NodeStatus in NodeController. |
ClusterName [Required]string | clusterName is the instance prefix for the cluster. |
ClusterCIDR [Required]string | clusterCIDR is CIDR Range for Pods in cluster. |
AllocateNodeCIDRs [Required]bool | AllocateNodeCIDRs enables CIDRs for Pods to be allocated and, if ConfigureCloudRoutes is true, to be set on the cloud provider. |
CIDRAllocatorType [Required]string | CIDRAllocatorType determines what kind of pod CIDR allocator will be used. |
ConfigureCloudRoutes [Required] | configureCloudRoutes enables CIDRs allocated with allocateNodeCIDRs to be configured on the cloud provider. |
NodeSyncPeriod [Required]meta/v1.Duration | nodeSyncPeriod is the period for syncing nodes from cloudprovider. Longer periods will result in fewer calls to cloud provider, but may delay addition of new nodes to cluster. |