mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	Signed-off-by: Harshal Patil <harpatil@redhat.com> Co-authored-by: Swarup Ghosh <swghosh@redhat.com>
		
			
				
	
	
		
			1110 lines
		
	
	
		
			38 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			1110 lines
		
	
	
		
			38 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2017 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 features
 | 
						|
 | 
						|
import (
 | 
						|
	"k8s.io/apimachinery/pkg/util/runtime"
 | 
						|
	genericfeatures "k8s.io/apiserver/pkg/features"
 | 
						|
	utilfeature "k8s.io/apiserver/pkg/util/feature"
 | 
						|
	"k8s.io/component-base/featuregate"
 | 
						|
)
 | 
						|
 | 
						|
const (
 | 
						|
	// Every feature gate should add method here following this template:
 | 
						|
	//
 | 
						|
	// // owner: @username
 | 
						|
	// // kep: https://kep.k8s.io/NNN
 | 
						|
	// // alpha: v1.X
 | 
						|
	// MyFeature featuregate.Feature = "MyFeature"
 | 
						|
	//
 | 
						|
	// Feature gates should be listed in alphabetical, case-sensitive
 | 
						|
	// (upper before any lower case character) order. This reduces the risk
 | 
						|
	// of code conflicts because changes are more likely to be scattered
 | 
						|
	// across the file.
 | 
						|
 | 
						|
	// owner: @bswartz
 | 
						|
	// alpha: v1.18
 | 
						|
	// beta: v1.24
 | 
						|
	//
 | 
						|
	// Enables usage of any object for volume data source in PVCs
 | 
						|
	AnyVolumeDataSource featuregate.Feature = "AnyVolumeDataSource"
 | 
						|
 | 
						|
	// owner: @nabokihms
 | 
						|
	// alpha: v1.26
 | 
						|
	//
 | 
						|
	// Enables API to get self subject attributes after authentication.
 | 
						|
	APISelfSubjectReview featuregate.Feature = "APISelfSubjectReview"
 | 
						|
 | 
						|
	// owner: @tallclair
 | 
						|
	// beta: v1.4
 | 
						|
	AppArmor featuregate.Feature = "AppArmor"
 | 
						|
 | 
						|
	// owner: @szuecs
 | 
						|
	// alpha: v1.12
 | 
						|
	//
 | 
						|
	// Enable nodes to change CPUCFSQuotaPeriod
 | 
						|
	CPUCFSQuotaPeriod featuregate.Feature = "CustomCPUCFSQuotaPeriod"
 | 
						|
 | 
						|
	// owner: @ConnorDoyle, @fromanirh (only for GA graduation)
 | 
						|
	// alpha: v1.8
 | 
						|
	// beta: v1.10
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Alternative container-level CPU affinity policies.
 | 
						|
	CPUManager featuregate.Feature = "CPUManager"
 | 
						|
 | 
						|
	// owner: @fromanirh
 | 
						|
	// alpha: v1.23
 | 
						|
	// beta: see below.
 | 
						|
	//
 | 
						|
	// Allow fine-tuning of cpumanager policies, experimental, alpha-quality options
 | 
						|
	// Per https://groups.google.com/g/kubernetes-sig-architecture/c/Nxsc7pfe5rw/m/vF2djJh0BAAJ
 | 
						|
	// We want to avoid a proliferation of feature gates. This feature gate:
 | 
						|
	// - will guard *a group* of cpumanager options whose quality level is alpha.
 | 
						|
	// - will never graduate to beta or stable.
 | 
						|
	// See https://groups.google.com/g/kubernetes-sig-architecture/c/Nxsc7pfe5rw/m/vF2djJh0BAAJ
 | 
						|
	// for details about the removal of this feature gate.
 | 
						|
	CPUManagerPolicyAlphaOptions featuregate.Feature = "CPUManagerPolicyAlphaOptions"
 | 
						|
 | 
						|
	// owner: @fromanirh
 | 
						|
	// beta: v1.23
 | 
						|
	// beta: see below.
 | 
						|
	//
 | 
						|
	// Allow fine-tuning of cpumanager policies, experimental, beta-quality options
 | 
						|
	// Per https://groups.google.com/g/kubernetes-sig-architecture/c/Nxsc7pfe5rw/m/vF2djJh0BAAJ
 | 
						|
	// We want to avoid a proliferation of feature gates. This feature gate:
 | 
						|
	// - will guard *a group* of cpumanager options whose quality level is beta.
 | 
						|
	// - is thus *introduced* as beta
 | 
						|
	// - will never graduate to stable.
 | 
						|
	// See https://groups.google.com/g/kubernetes-sig-architecture/c/Nxsc7pfe5rw/m/vF2djJh0BAAJ
 | 
						|
	// for details about the removal of this feature gate.
 | 
						|
	CPUManagerPolicyBetaOptions featuregate.Feature = "CPUManagerPolicyBetaOptions"
 | 
						|
 | 
						|
	// owner: @fromanirh
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.23
 | 
						|
	//
 | 
						|
	// Allow the usage of options to fine-tune the cpumanager policies.
 | 
						|
	CPUManagerPolicyOptions featuregate.Feature = "CPUManagerPolicyOptions"
 | 
						|
 | 
						|
	// owner: @pohly
 | 
						|
	// alpha: v1.14
 | 
						|
	// beta: v1.16
 | 
						|
	// GA: v1.25
 | 
						|
	//
 | 
						|
	// Enables CSI Inline volumes support for pods
 | 
						|
	CSIInlineVolume featuregate.Feature = "CSIInlineVolume"
 | 
						|
 | 
						|
	// owner: @davidz627
 | 
						|
	// alpha: v1.14
 | 
						|
	// beta: v1.17
 | 
						|
	//
 | 
						|
	// Enables the in-tree storage to CSI Plugin migration feature.
 | 
						|
	CSIMigration featuregate.Feature = "CSIMigration"
 | 
						|
 | 
						|
	// owner: @leakingtapan
 | 
						|
	// alpha: v1.14
 | 
						|
	// beta: v1.17
 | 
						|
	// GA: v1.25
 | 
						|
	//
 | 
						|
	// Enables the AWS EBS in-tree driver to AWS EBS CSI Driver migration feature.
 | 
						|
	CSIMigrationAWS featuregate.Feature = "CSIMigrationAWS"
 | 
						|
 | 
						|
	// owner: @andyzhangx
 | 
						|
	// alpha: v1.15
 | 
						|
	// beta: v1.19
 | 
						|
	// GA: v1.24
 | 
						|
	//
 | 
						|
	// Enables the Azure Disk in-tree driver to Azure Disk Driver migration feature.
 | 
						|
	CSIMigrationAzureDisk featuregate.Feature = "CSIMigrationAzureDisk"
 | 
						|
 | 
						|
	// owner: @andyzhangx
 | 
						|
	// alpha: v1.15
 | 
						|
	// beta: v1.21
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Enables the Azure File in-tree driver to Azure File Driver migration feature.
 | 
						|
	CSIMigrationAzureFile featuregate.Feature = "CSIMigrationAzureFile"
 | 
						|
 | 
						|
	// owner: @davidz627
 | 
						|
	// alpha: v1.14
 | 
						|
	// beta: v1.17
 | 
						|
	// GA: 1.25
 | 
						|
	//
 | 
						|
	// Enables the GCE PD in-tree driver to GCE CSI Driver migration feature.
 | 
						|
	CSIMigrationGCE featuregate.Feature = "CSIMigrationGCE"
 | 
						|
 | 
						|
	// owner: @trierra
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Enables the Portworx in-tree driver to Portworx migration feature.
 | 
						|
	CSIMigrationPortworx featuregate.Feature = "CSIMigrationPortworx"
 | 
						|
 | 
						|
	// owner: @humblec
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Enables the RBD in-tree driver to RBD CSI Driver  migration feature.
 | 
						|
	CSIMigrationRBD featuregate.Feature = "CSIMigrationRBD"
 | 
						|
 | 
						|
	// owner: @divyenpatel
 | 
						|
	// beta: v1.19 (requires: vSphere vCenter/ESXi Version: 7.0u2, HW Version: VM version 15)
 | 
						|
	// GA: 1.26
 | 
						|
	// Enables the vSphere in-tree driver to vSphere CSI Driver migration feature.
 | 
						|
	CSIMigrationvSphere featuregate.Feature = "CSIMigrationvSphere"
 | 
						|
 | 
						|
	// owner: @humblec, @zhucan
 | 
						|
	// kep: https://kep.k8s.io/3171
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables SecretRef field in CSI NodeExpandVolume request.
 | 
						|
	CSINodeExpandSecret featuregate.Feature = "CSINodeExpandSecret"
 | 
						|
 | 
						|
	// owner: @pohly
 | 
						|
	// alpha: v1.19
 | 
						|
	// beta: v1.21
 | 
						|
	// GA: v1.24
 | 
						|
	//
 | 
						|
	// Enables tracking of available storage capacity that CSI drivers provide.
 | 
						|
	CSIStorageCapacity featuregate.Feature = "CSIStorageCapacity"
 | 
						|
 | 
						|
	// owner: @fengzixu
 | 
						|
	// alpha: v1.21
 | 
						|
	//
 | 
						|
	// Enables kubelet to detect CSI volume condition and send the event of the abnormal volume to the corresponding pod that is using it.
 | 
						|
	CSIVolumeHealth featuregate.Feature = "CSIVolumeHealth"
 | 
						|
 | 
						|
	// owner: @adrianreber
 | 
						|
	// kep: https://kep.k8s.io/2008
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables container Checkpoint support in the kubelet
 | 
						|
	ContainerCheckpoint featuregate.Feature = "ContainerCheckpoint"
 | 
						|
 | 
						|
	// owner: @bhcleek @wzshiming
 | 
						|
	// GA: v1.25
 | 
						|
	//
 | 
						|
	// Normalize HttpGet URL and Header passing for lifecycle handlers with probers.
 | 
						|
	ConsistentHTTPGetHandlers featuregate.Feature = "ConsistentHTTPGetHandlers"
 | 
						|
 | 
						|
	// owner: @jiahuif
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta:  v1.22
 | 
						|
	// GA:    v1.24
 | 
						|
	//
 | 
						|
	// Enables Leader Migration for kube-controller-manager and cloud-controller-manager
 | 
						|
	ControllerManagerLeaderMigration featuregate.Feature = "ControllerManagerLeaderMigration"
 | 
						|
 | 
						|
	// owner: @deejross, @soltysh
 | 
						|
	// kep: https://kep.k8s.io/3140
 | 
						|
	// alpha: v1.24
 | 
						|
	// beta: v1.25
 | 
						|
	//
 | 
						|
	// Enables support for time zones in CronJobs.
 | 
						|
	CronJobTimeZone featuregate.Feature = "CronJobTimeZone"
 | 
						|
 | 
						|
	// owner: @smarterclayton
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.22
 | 
						|
	// GA: v1.25
 | 
						|
	// DaemonSets allow workloads to maintain availability during update per node
 | 
						|
	DaemonSetUpdateSurge featuregate.Feature = "DaemonSetUpdateSurge"
 | 
						|
 | 
						|
	// owner: @gnufied, @verult, @bertinatto
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.23
 | 
						|
	// GA: v1.26
 | 
						|
	// If supported by the CSI driver, delegates the role of applying FSGroup to
 | 
						|
	// the driver by passing FSGroup through the NodeStageVolume and
 | 
						|
	// NodePublishVolume calls.
 | 
						|
	DelegateFSGroupToCSIDriver featuregate.Feature = "DelegateFSGroupToCSIDriver"
 | 
						|
 | 
						|
	// owner: @jiayingz, @swatisehgal (for GA graduation)
 | 
						|
	// alpha: v1.8
 | 
						|
	// beta: v1.10
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Enables support for Device Plugins
 | 
						|
	DevicePlugins featuregate.Feature = "DevicePlugins"
 | 
						|
 | 
						|
	// owner: @RenaudWasTaken @dashpole
 | 
						|
	// alpha: v1.19
 | 
						|
	// beta: v1.20
 | 
						|
	// ga: v1.25
 | 
						|
	//
 | 
						|
	// Disables Accelerator Metrics Collected by Kubelet
 | 
						|
	DisableAcceleratorUsageMetrics featuregate.Feature = "DisableAcceleratorUsageMetrics"
 | 
						|
 | 
						|
	// owner: @andrewsykim
 | 
						|
	// alpha: v1.22
 | 
						|
	//
 | 
						|
	// Disable any functionality in kube-apiserver, kube-controller-manager and kubelet related to the `--cloud-provider` component flag.
 | 
						|
	DisableCloudProviders featuregate.Feature = "DisableCloudProviders"
 | 
						|
 | 
						|
	// owner: @andrewsykim
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Disable in-tree functionality in kubelet to authenticate to cloud provider container registries for image pull credentials.
 | 
						|
	DisableKubeletCloudCredentialProviders featuregate.Feature = "DisableKubeletCloudCredentialProviders"
 | 
						|
 | 
						|
	// owner: @derekwaynecarr
 | 
						|
	// alpha: v1.20
 | 
						|
	// beta: v1.21 (off by default until 1.22)
 | 
						|
	//
 | 
						|
	// Enables usage of hugepages-<size> in downward API.
 | 
						|
	DownwardAPIHugePages featuregate.Feature = "DownwardAPIHugePages"
 | 
						|
 | 
						|
	// owner: @andrewsykim
 | 
						|
	// kep: https://kep.k8s.io/1672
 | 
						|
	// alpha: v1.20
 | 
						|
	// beta: v1.22
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Enable Terminating condition in Endpoint Slices.
 | 
						|
	EndpointSliceTerminatingCondition featuregate.Feature = "EndpointSliceTerminatingCondition"
 | 
						|
 | 
						|
	// owner: @verb
 | 
						|
	// alpha: v1.16
 | 
						|
	// beta: v1.23
 | 
						|
	// GA: v1.25
 | 
						|
	//
 | 
						|
	// Allows running an ephemeral container in pod namespaces to troubleshoot a running pod.
 | 
						|
	EphemeralContainers featuregate.Feature = "EphemeralContainers"
 | 
						|
 | 
						|
	// owner: @harche
 | 
						|
	// kep: http://kep.k8s.io/3386
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Allows using event-driven PLEG (pod lifecycle event generator) through kubelet
 | 
						|
	// which avoids frequent relisting of containers which helps optimize performance.
 | 
						|
	EventedPLEG featuregate.Feature = "EventedPLEG"
 | 
						|
 | 
						|
	// owner: @andrewsykim @SergeyKanzhelev
 | 
						|
	// GA: v1.20
 | 
						|
	//
 | 
						|
	// Ensure kubelet respects exec probe timeouts. Feature gate exists in-case existing workloads
 | 
						|
	// may depend on old behavior where exec probe timeouts were ignored.
 | 
						|
	// Lock to default and remove after v1.22 based on user feedback that should be reflected in KEP #1972 update
 | 
						|
	ExecProbeTimeout featuregate.Feature = "ExecProbeTimeout"
 | 
						|
 | 
						|
	// owner: @gnufied
 | 
						|
	// alpha: v1.14
 | 
						|
	// beta: v1.16
 | 
						|
	// GA: 1.24
 | 
						|
	// Ability to expand CSI volumes
 | 
						|
	ExpandCSIVolumes featuregate.Feature = "ExpandCSIVolumes"
 | 
						|
 | 
						|
	// owner: @mlmhl @gnufied
 | 
						|
	// beta: v1.15
 | 
						|
	// GA: 1.24
 | 
						|
	// Ability to expand persistent volumes' file system without unmounting volumes.
 | 
						|
	ExpandInUsePersistentVolumes featuregate.Feature = "ExpandInUsePersistentVolumes"
 | 
						|
 | 
						|
	// owner: @gnufied
 | 
						|
	// beta: v1.11
 | 
						|
	// GA: 1.24
 | 
						|
	// Ability to Expand persistent volumes
 | 
						|
	ExpandPersistentVolumes featuregate.Feature = "ExpandPersistentVolumes"
 | 
						|
 | 
						|
	// owner: @gjkim42
 | 
						|
	// kep: https://kep.k8s.io/2595
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.26
 | 
						|
	//
 | 
						|
	// Enables apiserver and kubelet to allow up to 32 DNSSearchPaths and up to 2048 DNSSearchListChars.
 | 
						|
	ExpandedDNSConfig featuregate.Feature = "ExpandedDNSConfig"
 | 
						|
 | 
						|
	// owner: @pweil-
 | 
						|
	// alpha: v1.5
 | 
						|
	//
 | 
						|
	// Default userns=host for containers that are using other host namespaces, host mounts, the pod
 | 
						|
	// contains a privileged container, or specific non-namespaced capabilities (MKNOD, SYS_MODULE,
 | 
						|
	// SYS_TIME). This should only be enabled if user namespace remapping is enabled in the docker daemon.
 | 
						|
	ExperimentalHostUserNamespaceDefaultingGate featuregate.Feature = "ExperimentalHostUserNamespaceDefaulting"
 | 
						|
 | 
						|
	// owner: @yuzhiquan, @bowei, @PxyUp, @SergeyKanzhelev
 | 
						|
	// kep: https://kep.k8s.io/2727
 | 
						|
	// alpha: v1.23
 | 
						|
	// beta: v1.24
 | 
						|
	//
 | 
						|
	// Enables GRPC probe method for {Liveness,Readiness,Startup}Probe.
 | 
						|
	GRPCContainerProbe featuregate.Feature = "GRPCContainerProbe"
 | 
						|
 | 
						|
	// owner: @bobbypage
 | 
						|
	// alpha: v1.20
 | 
						|
	// beta:  v1.21
 | 
						|
	// Adds support for kubelet to detect node shutdown and gracefully terminate pods prior to the node being shutdown.
 | 
						|
	GracefulNodeShutdown featuregate.Feature = "GracefulNodeShutdown"
 | 
						|
 | 
						|
	// owner: @wzshiming
 | 
						|
	// alpha: v1.23
 | 
						|
	// beta:  v1.24
 | 
						|
	// Make the kubelet use shutdown configuration based on pod priority values for graceful shutdown.
 | 
						|
	GracefulNodeShutdownBasedOnPodPriority featuregate.Feature = "GracefulNodeShutdownBasedOnPodPriority"
 | 
						|
 | 
						|
	// owner: @arjunrn @mwielgus @josephburnett
 | 
						|
	// alpha: v1.20
 | 
						|
	//
 | 
						|
	// Add support for the HPA to scale based on metrics from individual containers
 | 
						|
	// in target pods
 | 
						|
	HPAContainerMetrics featuregate.Feature = "HPAContainerMetrics"
 | 
						|
 | 
						|
	// owner: @dxist
 | 
						|
	// alpha: v1.16
 | 
						|
	//
 | 
						|
	// Enables support of HPA scaling to zero pods when an object or custom metric is configured.
 | 
						|
	HPAScaleToZero featuregate.Feature = "HPAScaleToZero"
 | 
						|
 | 
						|
	// owner: @deepakkinni @xing-yang
 | 
						|
	// kep: https://kep.k8s.io/2680
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Honor Persistent Volume Reclaim Policy when it is "Delete" irrespective of PV-PVC
 | 
						|
	// deletion ordering.
 | 
						|
	HonorPVReclaimPolicy featuregate.Feature = "HonorPVReclaimPolicy"
 | 
						|
 | 
						|
	// owner: @ravig
 | 
						|
	// alpha: v1.23
 | 
						|
	// beta: v1.24
 | 
						|
	// GA: v1.25
 | 
						|
	// IdentifyPodOS allows user to specify OS on which they'd like the Pod run. The user should still set the nodeSelector
 | 
						|
	// with appropriate `kubernetes.io/os` label for scheduler to identify appropriate node for the pod to run.
 | 
						|
	IdentifyPodOS featuregate.Feature = "IdentifyPodOS"
 | 
						|
 | 
						|
	// owner: @leakingtapan
 | 
						|
	// alpha: v1.21
 | 
						|
	//
 | 
						|
	// Disables the AWS EBS in-tree driver.
 | 
						|
	InTreePluginAWSUnregister featuregate.Feature = "InTreePluginAWSUnregister"
 | 
						|
 | 
						|
	// owner: @andyzhangx
 | 
						|
	// alpha: v1.21
 | 
						|
	//
 | 
						|
	// Disables the Azure Disk in-tree driver.
 | 
						|
	InTreePluginAzureDiskUnregister featuregate.Feature = "InTreePluginAzureDiskUnregister"
 | 
						|
 | 
						|
	// owner: @andyzhangx
 | 
						|
	// alpha: v1.21
 | 
						|
	//
 | 
						|
	// Disables the Azure File in-tree driver.
 | 
						|
	InTreePluginAzureFileUnregister featuregate.Feature = "InTreePluginAzureFileUnregister"
 | 
						|
 | 
						|
	// owner: @Jiawei0227
 | 
						|
	// alpha: v1.21
 | 
						|
	//
 | 
						|
	// Disables the GCE PD in-tree driver.
 | 
						|
	InTreePluginGCEUnregister featuregate.Feature = "InTreePluginGCEUnregister"
 | 
						|
 | 
						|
	// owner: @trierra
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Disables the Portworx in-tree driver.
 | 
						|
	InTreePluginPortworxUnregister featuregate.Feature = "InTreePluginPortworxUnregister"
 | 
						|
 | 
						|
	// owner: @humblec
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Disables the RBD in-tree driver.
 | 
						|
	InTreePluginRBDUnregister featuregate.Feature = "InTreePluginRBDUnregister"
 | 
						|
 | 
						|
	// owner: @divyenpatel
 | 
						|
	// alpha: v1.21
 | 
						|
	//
 | 
						|
	// Disables the vSphere in-tree driver.
 | 
						|
	InTreePluginvSphereUnregister featuregate.Feature = "InTreePluginvSphereUnregister"
 | 
						|
 | 
						|
	// owner: @danwinship
 | 
						|
	// kep: https://kep.k8s.io/3178
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Causes kubelet to no longer create legacy IPTables rules
 | 
						|
	IPTablesOwnershipCleanup featuregate.Feature = "IPTablesOwnershipCleanup"
 | 
						|
 | 
						|
	// owner: @mimowo
 | 
						|
	// kep: https://kep.k8s.io/3329
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Allow users to specify handling of pod failures based on container exit codes
 | 
						|
	// and pod conditions.
 | 
						|
	JobPodFailurePolicy featuregate.Feature = "JobPodFailurePolicy"
 | 
						|
 | 
						|
	// owner: @ahg
 | 
						|
	// beta: v1.23
 | 
						|
	//
 | 
						|
	// Allow updating node scheduling directives in the pod template of jobs. Specifically,
 | 
						|
	// node affinity, selector and tolerations. This is allowed only for suspended jobs
 | 
						|
	// that have never been unsuspended before.
 | 
						|
	JobMutableNodeSchedulingDirectives featuregate.Feature = "JobMutableNodeSchedulingDirectives"
 | 
						|
 | 
						|
	// owner: @alculquicondor
 | 
						|
	// alpha: v1.23
 | 
						|
	// beta: v1.24
 | 
						|
	//
 | 
						|
	// Track the number of pods with Ready condition in the Job status.
 | 
						|
	JobReadyPods featuregate.Feature = "JobReadyPods"
 | 
						|
 | 
						|
	// owner: @alculquicondor
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.23
 | 
						|
	// stable: v1.26
 | 
						|
	//
 | 
						|
	// Track Job completion without relying on Pod remaining in the cluster
 | 
						|
	// indefinitely. Pod finalizers, in addition to a field in the Job status
 | 
						|
	// allow the Job controller to keep track of Pods that it didn't account for
 | 
						|
	// yet.
 | 
						|
	JobTrackingWithFinalizers featuregate.Feature = "JobTrackingWithFinalizers"
 | 
						|
 | 
						|
	// owner: @andrewsykim @adisky @ndixita
 | 
						|
	// alpha: v1.20
 | 
						|
	// beta: v1.24
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Enable kubelet exec plugins for image pull credentials.
 | 
						|
	KubeletCredentialProviders featuregate.Feature = "KubeletCredentialProviders"
 | 
						|
 | 
						|
	// owner: @AkihiroSuda
 | 
						|
	// alpha: v1.22
 | 
						|
	//
 | 
						|
	// Enables support for running kubelet in a user namespace.
 | 
						|
	// The user namespace has to be created before running kubelet.
 | 
						|
	// All the node components such as CRI need to be running in the same user namespace.
 | 
						|
	KubeletInUserNamespace featuregate.Feature = "KubeletInUserNamespace"
 | 
						|
 | 
						|
	// owner: @dashpole
 | 
						|
	// alpha: v1.13
 | 
						|
	// beta: v1.15
 | 
						|
	//
 | 
						|
	// Enables the kubelet's pod resources grpc endpoint
 | 
						|
	KubeletPodResources featuregate.Feature = "KubeletPodResources"
 | 
						|
 | 
						|
	// owner: @fromanirh
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.23
 | 
						|
	// Enable POD resources API to return allocatable resources
 | 
						|
	KubeletPodResourcesGetAllocatable featuregate.Feature = "KubeletPodResourcesGetAllocatable"
 | 
						|
 | 
						|
	// owner: @sallyom
 | 
						|
	// kep: https://kep.k8s.io/2832
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Add support for distributed tracing in the kubelet
 | 
						|
	KubeletTracing featuregate.Feature = "KubeletTracing"
 | 
						|
 | 
						|
	// owner: @zshihang
 | 
						|
	// kep: https://kep.k8s.io/2800
 | 
						|
	// beta: v1.24
 | 
						|
	//
 | 
						|
	// Stop auto-generation of secret-based service account tokens.
 | 
						|
	LegacyServiceAccountTokenNoAutoGeneration featuregate.Feature = "LegacyServiceAccountTokenNoAutoGeneration"
 | 
						|
 | 
						|
	// owner: @zshihang
 | 
						|
	// kep: http://kep.k8s.io/2800
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables tracking of secret-based service account tokens usage.
 | 
						|
	LegacyServiceAccountTokenTracking featuregate.Feature = "LegacyServiceAccountTokenTracking"
 | 
						|
 | 
						|
	// owner: @jinxu
 | 
						|
	// beta: v1.10
 | 
						|
	// stable: v1.25
 | 
						|
	//
 | 
						|
	// Support local ephemeral storage types for local storage capacity isolation feature.
 | 
						|
	LocalStorageCapacityIsolation featuregate.Feature = "LocalStorageCapacityIsolation"
 | 
						|
 | 
						|
	// owner: @RobertKrawitz
 | 
						|
	// alpha: v1.15
 | 
						|
	//
 | 
						|
	// Allow use of filesystems for ephemeral storage monitoring.
 | 
						|
	// Only applies if LocalStorageCapacityIsolation is set.
 | 
						|
	LocalStorageCapacityIsolationFSQuotaMonitoring featuregate.Feature = "LocalStorageCapacityIsolationFSQuotaMonitoring"
 | 
						|
 | 
						|
	// owner: @damemi
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.22
 | 
						|
	//
 | 
						|
	// Enables scaling down replicas via logarithmic comparison of creation/ready timestamps
 | 
						|
	LogarithmicScaleDown featuregate.Feature = "LogarithmicScaleDown"
 | 
						|
 | 
						|
	// owner: @denkensk
 | 
						|
	// kep: https://kep.k8s.io/3243
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enable MatchLabelKeys in PodTopologySpread.
 | 
						|
	MatchLabelKeysInPodTopologySpread featuregate.Feature = "MatchLabelKeysInPodTopologySpread"
 | 
						|
 | 
						|
	// owner: @krmayankk
 | 
						|
	// alpha: v1.24
 | 
						|
	//
 | 
						|
	// Enables maxUnavailable for StatefulSet
 | 
						|
	MaxUnavailableStatefulSet featuregate.Feature = "MaxUnavailableStatefulSet"
 | 
						|
 | 
						|
	// owner: @cynepco3hahue(alukiano) @cezaryzukowski @k-wiatrzyk
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.22
 | 
						|
	// Allows setting memory affinity for a container based on NUMA topology
 | 
						|
	MemoryManager featuregate.Feature = "MemoryManager"
 | 
						|
 | 
						|
	// owner: @xiaoxubeii
 | 
						|
	// kep: https://kep.k8s.io/2570
 | 
						|
	// alpha: v1.22
 | 
						|
	//
 | 
						|
	// Enables kubelet to support memory QoS with cgroups v2.
 | 
						|
	MemoryQoS featuregate.Feature = "MemoryQoS"
 | 
						|
 | 
						|
	// owner: @sanposhiho
 | 
						|
	// kep: https://kep.k8s.io/3022
 | 
						|
	// alpha: v1.24
 | 
						|
	// beta: v1.25
 | 
						|
	//
 | 
						|
	// Enable MinDomains in Pod Topology Spread.
 | 
						|
	MinDomainsInPodTopologySpread featuregate.Feature = "MinDomainsInPodTopologySpread"
 | 
						|
 | 
						|
	// owner: @danwinship
 | 
						|
	// kep: http://kep.k8s.io/3453
 | 
						|
	// alpha: v1.26
 | 
						|
	//
 | 
						|
	// Enables new performance-improving code in kube-proxy iptables mode
 | 
						|
	MinimizeIPTablesRestore featuregate.Feature = "MinimizeIPTablesRestore"
 | 
						|
 | 
						|
	// owner: @janosi @bridgetkromhout
 | 
						|
	// kep: https://kep.k8s.io/1435
 | 
						|
	// alpha: v1.20
 | 
						|
	// beta: v1.24
 | 
						|
	// ga: v1.26
 | 
						|
	//
 | 
						|
	// Enables the usage of different protocols in the same Service with type=LoadBalancer
 | 
						|
	MixedProtocolLBService featuregate.Feature = "MixedProtocolLBService"
 | 
						|
 | 
						|
	// owner: @sarveshr7
 | 
						|
	// kep: https://kep.k8s.io/2593
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables the MultiCIDR Range allocator.
 | 
						|
	MultiCIDRRangeAllocator featuregate.Feature = "MultiCIDRRangeAllocator"
 | 
						|
 | 
						|
	// owner: @rikatz
 | 
						|
	// kep: https://kep.k8s.io/2079
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta:  v1.22
 | 
						|
	// ga: v1.25
 | 
						|
	//
 | 
						|
	// Enables the endPort field in NetworkPolicy to enable a Port Range behavior in Network Policies.
 | 
						|
	NetworkPolicyEndPort featuregate.Feature = "NetworkPolicyEndPort"
 | 
						|
 | 
						|
	// owner: @rikatz
 | 
						|
	// kep: https://kep.k8s.io/2943
 | 
						|
	// alpha: v1.24
 | 
						|
	//
 | 
						|
	// Enables NetworkPolicy status subresource
 | 
						|
	NetworkPolicyStatus featuregate.Feature = "NetworkPolicyStatus"
 | 
						|
 | 
						|
	// owner: @xing-yang @sonasingh46
 | 
						|
	// kep: https://kep.k8s.io/2268
 | 
						|
	// alpha: v1.24
 | 
						|
	// beta: v1.26
 | 
						|
	//
 | 
						|
	// Allow pods to failover to a different node in case of non graceful node shutdown
 | 
						|
	NodeOutOfServiceVolumeDetach featuregate.Feature = "NodeOutOfServiceVolumeDetach"
 | 
						|
 | 
						|
	// owner: @ehashman
 | 
						|
	// alpha: v1.22
 | 
						|
	//
 | 
						|
	// Permits kubelet to run with swap enabled
 | 
						|
	NodeSwap featuregate.Feature = "NodeSwap"
 | 
						|
 | 
						|
	// owner: @haircommander
 | 
						|
	// kep: https://kep.k8s.io/2364
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Configures the Kubelet to use the CRI to populate pod and container stats, instead of supplimenting with stats from cAdvisor.
 | 
						|
	// Requires the CRI implementation supports supplying the required stats.
 | 
						|
	PodAndContainerStatsFromCRI featuregate.Feature = "PodAndContainerStatsFromCRI"
 | 
						|
 | 
						|
	// owner: @ahg-g
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.22
 | 
						|
	//
 | 
						|
	// Enables controlling pod ranking on replicaset scale-down.
 | 
						|
	PodDeletionCost featuregate.Feature = "PodDeletionCost"
 | 
						|
 | 
						|
	// owner: @mimowo
 | 
						|
	// kep: https://kep.k8s.io/3329
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables support for appending a dedicated pod condition indicating that
 | 
						|
	// the pod is being deleted due to a disruption.
 | 
						|
	PodDisruptionConditions featuregate.Feature = "PodDisruptionConditions"
 | 
						|
 | 
						|
	// owner: @ddebroy
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables reporting of PodHasNetwork condition in pod status after pod
 | 
						|
	// sandbox creation and network configuration completes successfully
 | 
						|
	PodHasNetworkCondition featuregate.Feature = "PodHasNetworkCondition"
 | 
						|
 | 
						|
	// owner: @Huang-Wei
 | 
						|
	// kep: https://kep.k8s.io/3521
 | 
						|
	// alpha: v1.26
 | 
						|
	//
 | 
						|
	// Enable users to specify when a Pod is ready for scheduling.
 | 
						|
	PodSchedulingReadiness featuregate.Feature = "PodSchedulingReadiness"
 | 
						|
 | 
						|
	// owner: @liggitt, @tallclair, sig-auth
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.23
 | 
						|
	// ga: v1.25
 | 
						|
	//
 | 
						|
	// Enables the PodSecurity admission plugin
 | 
						|
	PodSecurity featuregate.Feature = "PodSecurity"
 | 
						|
 | 
						|
	// owner: @ehashman
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.22
 | 
						|
	//
 | 
						|
	// Allows user to override pod-level terminationGracePeriod for probes
 | 
						|
	ProbeTerminationGracePeriod featuregate.Feature = "ProbeTerminationGracePeriod"
 | 
						|
 | 
						|
	// owner: @jessfraz
 | 
						|
	// alpha: v1.12
 | 
						|
	//
 | 
						|
	// Enables control over ProcMountType for containers.
 | 
						|
	ProcMountType featuregate.Feature = "ProcMountType"
 | 
						|
 | 
						|
	// owner: @andrewsykim
 | 
						|
	// kep: https://kep.k8s.io/1669
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.26
 | 
						|
	//
 | 
						|
	// Enable kube-proxy to handle terminating ednpoints when externalTrafficPolicy=Local
 | 
						|
	ProxyTerminatingEndpoints featuregate.Feature = "ProxyTerminatingEndpoints"
 | 
						|
 | 
						|
	// owner: @sjenning
 | 
						|
	// alpha: v1.11
 | 
						|
	//
 | 
						|
	// Allows resource reservations at the QoS level preventing pods at lower QoS levels from
 | 
						|
	// bursting into resources requested at higher QoS levels (memory only for now)
 | 
						|
	QOSReserved featuregate.Feature = "QOSReserved"
 | 
						|
 | 
						|
	// owner: @chrishenzie
 | 
						|
	// alpha: v1.22
 | 
						|
	//
 | 
						|
	// Enables usage of the ReadWriteOncePod PersistentVolume access mode.
 | 
						|
	ReadWriteOncePod featuregate.Feature = "ReadWriteOncePod"
 | 
						|
 | 
						|
	// owner: @gnufied
 | 
						|
	// kep: https://kep.k8s.io/1790
 | 
						|
	// alpha: v1.23
 | 
						|
	//
 | 
						|
	// Allow users to recover from volume expansion failure
 | 
						|
	RecoverVolumeExpansionFailure featuregate.Feature = "RecoverVolumeExpansionFailure"
 | 
						|
 | 
						|
	// owner: @RomanBednar
 | 
						|
	// kep: https://kep.k8s.io/3333
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Allow assigning StorageClass to unbound PVCs retroactively
 | 
						|
	RetroactiveDefaultStorageClass featuregate.Feature = "RetroactiveDefaultStorageClass"
 | 
						|
 | 
						|
	// owner: @mikedanese
 | 
						|
	// alpha: v1.7
 | 
						|
	// beta: v1.12
 | 
						|
	//
 | 
						|
	// Gets a server certificate for the kubelet from the Certificate Signing
 | 
						|
	// Request API instead of generating one self signed and auto rotates the
 | 
						|
	// certificate as expiration approaches.
 | 
						|
	RotateKubeletServerCertificate featuregate.Feature = "RotateKubeletServerCertificate"
 | 
						|
 | 
						|
	// owner: @saschagrunert
 | 
						|
	// kep: https://kep.k8s.io/2413
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.25
 | 
						|
	//
 | 
						|
	// Enables the use of `RuntimeDefault` as the default seccomp profile for all workloads.
 | 
						|
	SeccompDefault featuregate.Feature = "SeccompDefault"
 | 
						|
 | 
						|
	// owner: @maplain @andrewsykim
 | 
						|
	// kep: https://kep.k8s.io/2086
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.22
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Enables node-local routing for Service internal traffic
 | 
						|
	ServiceInternalTrafficPolicy featuregate.Feature = "ServiceInternalTrafficPolicy"
 | 
						|
 | 
						|
	// owner: @aojea
 | 
						|
	// kep: https://kep.k8s.io/3070
 | 
						|
	// alpha: v1.24
 | 
						|
	// beta: v1.25
 | 
						|
	// ga: v1.26
 | 
						|
	//
 | 
						|
	// Subdivide the ClusterIP range for dynamic and static IP allocation.
 | 
						|
	ServiceIPStaticSubrange featuregate.Feature = "ServiceIPStaticSubrange"
 | 
						|
 | 
						|
	// owner: @derekwaynecarr
 | 
						|
	// alpha: v1.20
 | 
						|
	// beta: v1.22
 | 
						|
	//
 | 
						|
	// Enables kubelet support to size memory backed volumes
 | 
						|
	SizeMemoryBackedVolumes featuregate.Feature = "SizeMemoryBackedVolumes"
 | 
						|
 | 
						|
	// owner: @mattcary
 | 
						|
	// alpha: v1.22
 | 
						|
	//
 | 
						|
	// Enables policies controlling deletion of PVCs created by a StatefulSet.
 | 
						|
	StatefulSetAutoDeletePVC featuregate.Feature = "StatefulSetAutoDeletePVC"
 | 
						|
 | 
						|
	// owner: @ravig
 | 
						|
	// kep: https://kep.k8s.io/2607
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.23
 | 
						|
	// GA: v1.25
 | 
						|
	// StatefulSetMinReadySeconds allows minReadySeconds to be respected by StatefulSet controller
 | 
						|
	StatefulSetMinReadySeconds featuregate.Feature = "StatefulSetMinReadySeconds"
 | 
						|
 | 
						|
	// owner: @robscott
 | 
						|
	// kep: https://kep.k8s.io/2433
 | 
						|
	// alpha: v1.21
 | 
						|
	// beta: v1.23
 | 
						|
	//
 | 
						|
	// Enables topology aware hints for EndpointSlices
 | 
						|
	TopologyAwareHints featuregate.Feature = "TopologyAwareHints"
 | 
						|
 | 
						|
	// owner: @lmdaly
 | 
						|
	// alpha: v1.16
 | 
						|
	// beta: v1.18
 | 
						|
	//
 | 
						|
	// Enable resource managers to make NUMA aligned decisions
 | 
						|
	TopologyManager featuregate.Feature = "TopologyManager"
 | 
						|
 | 
						|
	// owner: @rata, @giuseppe
 | 
						|
	// kep: https://kep.k8s.io/127
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Enables user namespace support for stateless pods.
 | 
						|
	UserNamespacesStatelessPodsSupport featuregate.Feature = "UserNamespacesStatelessPodsSupport"
 | 
						|
 | 
						|
	// owner: @cofyc
 | 
						|
	// alpha: v1.21
 | 
						|
	VolumeCapacityPriority featuregate.Feature = "VolumeCapacityPriority"
 | 
						|
 | 
						|
	// owner: @ksubrmnn
 | 
						|
	// alpha: v1.14
 | 
						|
	//
 | 
						|
	// Allows kube-proxy to create DSR loadbalancers for Windows
 | 
						|
	WinDSR featuregate.Feature = "WinDSR"
 | 
						|
 | 
						|
	// owner: @ksubrmnn
 | 
						|
	// alpha: v1.14
 | 
						|
	// beta: v1.20
 | 
						|
	//
 | 
						|
	// Allows kube-proxy to run in Overlay mode for Windows
 | 
						|
	WinOverlay featuregate.Feature = "WinOverlay"
 | 
						|
 | 
						|
	// owner: @marosset
 | 
						|
	// kep: https://kep.k8s.io/3503
 | 
						|
	// alpha: v1.26
 | 
						|
	//
 | 
						|
	// Enables support for joining Windows containers to a hosts' network namespace.
 | 
						|
	WindowsHostNetwork featuregate.Feature = "WindowsHostNetwork"
 | 
						|
 | 
						|
	// owner: @marosset
 | 
						|
	// alpha: v1.22
 | 
						|
	// beta: v1.23
 | 
						|
	// GA: v1.26
 | 
						|
	//
 | 
						|
	// Enables support for 'HostProcess' containers on Windows nodes.
 | 
						|
	WindowsHostProcessContainers featuregate.Feature = "WindowsHostProcessContainers"
 | 
						|
 | 
						|
	// owner: @kerthcet
 | 
						|
	// kep: https://kep.k8s.io/3094
 | 
						|
	// alpha: v1.25
 | 
						|
	//
 | 
						|
	// Allow users to specify whether to take nodeAffinity/nodeTaint into consideration when
 | 
						|
	// calculating pod topology spread skew.
 | 
						|
	NodeInclusionPolicyInPodTopologySpread featuregate.Feature = "NodeInclusionPolicyInPodTopologySpread"
 | 
						|
 | 
						|
	// owner: @jsafrane
 | 
						|
	// kep: https://kep.k8s.io/1710
 | 
						|
	// alpha: v1.25
 | 
						|
	// Speed up container startup by mounting volumes with the correct SELinux label
 | 
						|
	// instead of changing each file on the volumes recursively.
 | 
						|
	// Initial implementation focused on ReadWriteOncePod volumes.
 | 
						|
	SELinuxMountReadWriteOncePod featuregate.Feature = "SELinuxMountReadWriteOncePod"
 | 
						|
)
 | 
						|
 | 
						|
func init() {
 | 
						|
	runtime.Must(utilfeature.DefaultMutableFeatureGate.Add(defaultKubernetesFeatureGates))
 | 
						|
}
 | 
						|
 | 
						|
// defaultKubernetesFeatureGates consists of all known Kubernetes-specific feature keys.
 | 
						|
// To add a new feature, define a key for it above and add it here. The features will be
 | 
						|
// available throughout Kubernetes binaries.
 | 
						|
//
 | 
						|
// Entries are separated from each other with blank lines to avoid sweeping gofmt changes
 | 
						|
// when adding or removing one entry.
 | 
						|
var defaultKubernetesFeatureGates = map[featuregate.Feature]featuregate.FeatureSpec{
 | 
						|
	AnyVolumeDataSource: {Default: true, PreRelease: featuregate.Beta}, // on by default in 1.24
 | 
						|
 | 
						|
	APISelfSubjectReview: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	AppArmor: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	CPUCFSQuotaPeriod: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	CPUManager: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // GA in 1.26
 | 
						|
 | 
						|
	CPUManagerPolicyAlphaOptions: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	CPUManagerPolicyBetaOptions: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	CPUManagerPolicyOptions: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	CSIInlineVolume: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	CSIMigration: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	CSIMigrationAWS: {Default: true, PreRelease: featuregate.GA, LockToDefault: true},
 | 
						|
 | 
						|
	CSIMigrationAzureDisk: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // On by default in 1.23 (requires Azure Disk CSI driver)
 | 
						|
 | 
						|
	CSIMigrationAzureFile: {Default: true, PreRelease: featuregate.GA}, // On by default in 1.24 (requires Azure File CSI driver)
 | 
						|
 | 
						|
	CSIMigrationGCE: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // GA in 1.25 (requires GCE PD CSI Driver)
 | 
						|
 | 
						|
	CSIMigrationPortworx: {Default: false, PreRelease: featuregate.Beta}, // Off by default (requires Portworx CSI driver)
 | 
						|
 | 
						|
	CSIMigrationRBD: {Default: false, PreRelease: featuregate.Alpha}, // Off by default (requires RBD CSI driver)
 | 
						|
 | 
						|
	CSIMigrationvSphere: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	CSINodeExpandSecret: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	CSIStorageCapacity: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.26
 | 
						|
 | 
						|
	CSIVolumeHealth: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	ContainerCheckpoint: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	ConsistentHTTPGetHandlers: {Default: true, PreRelease: featuregate.GA},
 | 
						|
 | 
						|
	ControllerManagerLeaderMigration: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.26
 | 
						|
 | 
						|
	CronJobTimeZone: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	DaemonSetUpdateSurge: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	DelegateFSGroupToCSIDriver: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	DevicePlugins: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // GA in 1.26
 | 
						|
 | 
						|
	DisableAcceleratorUsageMetrics: {Default: true, PreRelease: featuregate.GA, LockToDefault: true},
 | 
						|
 | 
						|
	DisableCloudProviders: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	DisableKubeletCloudCredentialProviders: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	DownwardAPIHugePages: {Default: true, PreRelease: featuregate.Beta}, // on by default in 1.22
 | 
						|
 | 
						|
	EndpointSliceTerminatingCondition: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in v1.28
 | 
						|
 | 
						|
	EphemeralContainers: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	EventedPLEG: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	ExecProbeTimeout: {Default: true, PreRelease: featuregate.GA}, // lock to default and remove after v1.22 based on KEP #1972 update
 | 
						|
 | 
						|
	ExpandCSIVolumes: {Default: true, PreRelease: featuregate.GA}, // remove in 1.26
 | 
						|
 | 
						|
	ExpandInUsePersistentVolumes: {Default: true, PreRelease: featuregate.GA}, // remove in 1.26
 | 
						|
 | 
						|
	ExpandPersistentVolumes: {Default: true, PreRelease: featuregate.GA}, // remove in 1.26
 | 
						|
 | 
						|
	ExpandedDNSConfig: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	ExperimentalHostUserNamespaceDefaultingGate: {Default: false, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	GRPCContainerProbe: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	GracefulNodeShutdown: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	GracefulNodeShutdownBasedOnPodPriority: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	HPAContainerMetrics: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	HonorPVReclaimPolicy: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	IdentifyPodOS: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	InTreePluginAWSUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	InTreePluginAzureDiskUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	InTreePluginAzureFileUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	InTreePluginGCEUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	InTreePluginPortworxUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	InTreePluginRBDUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	InTreePluginvSphereUnregister: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	IPTablesOwnershipCleanup: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	JobPodFailurePolicy: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	JobMutableNodeSchedulingDirectives: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	JobReadyPods: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	JobTrackingWithFinalizers: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	KubeletCredentialProviders: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	KubeletInUserNamespace: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	KubeletPodResources: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	KubeletPodResourcesGetAllocatable: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	KubeletTracing: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	LegacyServiceAccountTokenNoAutoGeneration: {Default: true, PreRelease: featuregate.GA},
 | 
						|
 | 
						|
	LegacyServiceAccountTokenTracking: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	LocalStorageCapacityIsolation: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	LocalStorageCapacityIsolationFSQuotaMonitoring: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	LogarithmicScaleDown: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	MatchLabelKeysInPodTopologySpread: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	MaxUnavailableStatefulSet: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	MemoryManager: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	MemoryQoS: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	MinDomainsInPodTopologySpread: {Default: false, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	MinimizeIPTablesRestore: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	MixedProtocolLBService: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	MultiCIDRRangeAllocator: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	NetworkPolicyEndPort: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	NetworkPolicyStatus: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	NodeOutOfServiceVolumeDetach: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	NodeSwap: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	PodAndContainerStatsFromCRI: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	PodDeletionCost: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	PodDisruptionConditions: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	PodHasNetworkCondition: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	PodSchedulingReadiness: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	PodSecurity: {Default: true, PreRelease: featuregate.GA, LockToDefault: true},
 | 
						|
 | 
						|
	ProbeTerminationGracePeriod: {Default: true, PreRelease: featuregate.Beta}, // Default to true in beta 1.25
 | 
						|
 | 
						|
	ProcMountType: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	ProxyTerminatingEndpoints: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	QOSReserved: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	ReadWriteOncePod: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	RecoverVolumeExpansionFailure: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	RetroactiveDefaultStorageClass: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	RotateKubeletServerCertificate: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	SeccompDefault: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	ServiceIPStaticSubrange: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	ServiceInternalTrafficPolicy: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	SizeMemoryBackedVolumes: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	StatefulSetAutoDeletePVC: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	StatefulSetMinReadySeconds: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.27
 | 
						|
 | 
						|
	TopologyAwareHints: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	TopologyManager: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	VolumeCapacityPriority: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	UserNamespacesStatelessPodsSupport: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	WinDSR: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	WinOverlay: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	WindowsHostNetwork: {Default: true, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	WindowsHostProcessContainers: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	NodeInclusionPolicyInPodTopologySpread: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	SELinuxMountReadWriteOncePod: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	// inherited features from generic apiserver, relisted here to get a conflict if it is changed
 | 
						|
	// unintentionally on either side:
 | 
						|
 | 
						|
	genericfeatures.AggregatedDiscoveryEndpoint: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	genericfeatures.APIListChunking: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	genericfeatures.APIPriorityAndFairness: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	genericfeatures.APIResponseCompression: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	genericfeatures.AdvancedAuditing: {Default: true, PreRelease: featuregate.GA},
 | 
						|
 | 
						|
	genericfeatures.CELValidatingAdmission: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
 | 
						|
	genericfeatures.CustomResourceValidationExpressions: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	genericfeatures.DryRun: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.28
 | 
						|
 | 
						|
	genericfeatures.OpenAPIEnums: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	genericfeatures.OpenAPIV3: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	genericfeatures.ServerSideApply: {Default: true, PreRelease: featuregate.GA, LockToDefault: true}, // remove in 1.29
 | 
						|
 | 
						|
	genericfeatures.ServerSideFieldValidation: {Default: true, PreRelease: featuregate.Beta},
 | 
						|
 | 
						|
	// features that enable backwards compatibility but are scheduled to be removed
 | 
						|
	// ...
 | 
						|
	HPAScaleToZero: {Default: false, PreRelease: featuregate.Alpha},
 | 
						|
}
 |