Docs for pod deletion cost feature
This commit is contained in:
		
							parent
							
								
									d0544c2f64
								
							
						
					
					
						commit
						290a652991
					
				|  | @ -321,6 +321,36 @@ prioritize scaling down pods based on the following general algorithm: | ||||||
|      |      | ||||||
| If all of the above match, then selection is random. | If all of the above match, then selection is random. | ||||||
| 
 | 
 | ||||||
|  | ### Pod deletion cost  | ||||||
|  | {{< feature-state for_k8s_version="v1.21" state="alpha" >}} | ||||||
|  | 
 | ||||||
|  | Using the [`controller.kubernetes.io/pod-deletion-cost`](/docs/reference/command-line-tools-reference/labels-annotations-taints/#pod-deletion-cost)  | ||||||
|  | annotation, users can set a preference regarding which pods to remove first when downscaling a ReplicaSet. | ||||||
|  | 
 | ||||||
|  | The annotation should be set on the pod, the range is [-2147483647, 2147483647]. It represents the cost of | ||||||
|  | deleting a pod compared to other pods belonging to the same ReplicaSet. Pods with lower deletion | ||||||
|  | cost are preferred to be deleted before pods with higher deletion cost.  | ||||||
|  | 
 | ||||||
|  | The implicit value for this annotation for pods that don't set it is 0; negative values are permitted. | ||||||
|  | Invalid values will be rejected by the API server. | ||||||
|  | 
 | ||||||
|  | This feature is alpha and disabled by default. You can enable it by setting the | ||||||
|  | [feature gate](/docs/reference/command-line-tools-reference/feature-gates/) | ||||||
|  | `PodDeletionCost` in both kube-apiserver and kube-controller-manager. | ||||||
|  | 
 | ||||||
|  | {{< note >}} | ||||||
|  | - This is honored on a best-effort basis, so it does not offer any guarantees on pod deletion order. | ||||||
|  | - Users should avoid updating the annotation frequently, such as updating it based on a metric value, | ||||||
|  |   because doing so will generate a significant number of pod updates on the apiserver. | ||||||
|  | {{< /note >}} | ||||||
|  | 
 | ||||||
|  | #### Example Use Case | ||||||
|  | The different pods of an application could have different utilization levels. On scale down, the application  | ||||||
|  | may prefer to remove the pods with lower utilization. To avoid frequently updating the pods, the application | ||||||
|  | should update `controller.kubernetes.io/pod-deletion-cost` once before issuing a scale down (setting the  | ||||||
|  | annotation to a value proportional to pod utilization level). This works if the application itself controls | ||||||
|  | the down scaling; for example, the driver pod of a Spark deployment. | ||||||
|  | 
 | ||||||
| ### ReplicaSet as a Horizontal Pod Autoscaler Target | ### ReplicaSet as a Horizontal Pod Autoscaler Target | ||||||
| 
 | 
 | ||||||
| A ReplicaSet can also be a target for | A ReplicaSet can also be a target for | ||||||
|  |  | ||||||
|  | @ -141,6 +141,7 @@ different Kubernetes components. | ||||||
| | `NodeDisruptionExclusion` | `true` | Beta | 1.19 | | | | `NodeDisruptionExclusion` | `true` | Beta | 1.19 | | | ||||||
| | `NonPreemptingPriority` | `false` | Alpha | 1.15 | 1.18 | | | `NonPreemptingPriority` | `false` | Alpha | 1.15 | 1.18 | | ||||||
| | `NonPreemptingPriority` | `true` | Beta | 1.19 | | | | `NonPreemptingPriority` | `true` | Beta | 1.19 | | | ||||||
|  | | `PodDeletionCost` | `false` | Alpha | 1.21 | | | ||||||
| | `PodDisruptionBudget` | `false` | Alpha | 1.3 | 1.4 | | | `PodDisruptionBudget` | `false` | Alpha | 1.3 | 1.4 | | ||||||
| | `PodDisruptionBudget` | `true` | Beta | 1.5 | | | | `PodDisruptionBudget` | `true` | Beta | 1.5 | | | ||||||
| | `PodAffinityNamespaceSelector` | `false` | Alpha | 1.21 | | | | `PodAffinityNamespaceSelector` | `false` | Alpha | 1.21 | | | ||||||
|  | @ -682,6 +683,8 @@ Each feature gate is designed for enabling/disabling a specific feature: | ||||||
| - `NonPreemptingPriority`: Enable `preemptionPolicy` field for PriorityClass and Pod. | - `NonPreemptingPriority`: Enable `preemptionPolicy` field for PriorityClass and Pod. | ||||||
| - `PVCProtection`: Enable the prevention of a PersistentVolumeClaim (PVC) from | - `PVCProtection`: Enable the prevention of a PersistentVolumeClaim (PVC) from | ||||||
|   being deleted when it is still used by any Pod. |   being deleted when it is still used by any Pod. | ||||||
|  | - `PodDeletionCost`: Enable the [Pod Deletion Cost](/docs/content/en/docs/concepts/workloads/controllers/replicaset/#pod-deletion-cost) | ||||||
|  |    feature which allows users to influence ReplicaSet downscaling order. | ||||||
| - `PersistentLocalVolumes`: Enable the usage of `local` volume type in Pods. | - `PersistentLocalVolumes`: Enable the usage of `local` volume type in Pods. | ||||||
|   Pod affinity has to be specified if requesting a `local` volume. |   Pod affinity has to be specified if requesting a `local` volume. | ||||||
| - `PodDisruptionBudget`: Enable the [PodDisruptionBudget](/docs/tasks/run-application/configure-pdb/) feature. | - `PodDisruptionBudget`: Enable the [PodDisruptionBudget](/docs/tasks/run-application/configure-pdb/) feature. | ||||||
|  |  | ||||||
|  | @ -56,6 +56,16 @@ The Kubelet populates this label with the hostname. Note that the hostname can b | ||||||
| 
 | 
 | ||||||
| This label is also used as part of the topology hierarchy.  See [topology.kubernetes.io/zone](#topologykubernetesiozone) for more information. | This label is also used as part of the topology hierarchy.  See [topology.kubernetes.io/zone](#topologykubernetesiozone) for more information. | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | ## controller.kubernetes.io/pod-deletion-cost {#pod-deletion-cost} | ||||||
|  | 
 | ||||||
|  | Example: `controller.kubernetes.io/pod-deletion-cost=10` | ||||||
|  | 
 | ||||||
|  | Used on: Pod | ||||||
|  | 
 | ||||||
|  | This annotation is used to set [Pod Deletion Cost](/docs/content/en/docs/concepts/workloads/controllers/replicaset/#pod-deletion-cost) | ||||||
|  | which allows users to influence ReplicaSet downscaling order. The annotation parses into an `int32` type. | ||||||
|  | 
 | ||||||
| ## beta.kubernetes.io/instance-type (deprecated) | ## beta.kubernetes.io/instance-type (deprecated) | ||||||
| 
 | 
 | ||||||
| {{< note >}} Starting in v1.17, this label is deprecated in favor of [node.kubernetes.io/instance-type](#nodekubernetesioinstance-type). {{< /note >}} | {{< note >}} Starting in v1.17, this label is deprecated in favor of [node.kubernetes.io/instance-type](#nodekubernetesioinstance-type). {{< /note >}} | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue