Update strategy
editUpdate strategy
editYou can use the updateStrategy
specification to limit the number of simultaneous changes, like for example in the following cases:
- The operator takes a Pod down to restart a node and applies a new configuration value.
- The operator must spin up Pods above what is currently in the specification to migrate to a new node set.
spec: updateStrategy: changeBudget: maxSurge: 3 maxUnavailable: 1
maxSurge
: Refers to the number of extra Pods that can be temporarily scheduled exceeding the number of Pods defined in the specification. This setting is useful for controlling the resource usage of the Kubernetes cluster when new Pods need to be spun up to replace existing Pods. For example, when applying a configuration change to a Node Set, ECK creates a clone of the Node Set with the desired configuration and shuts down the old Pods. Without the MaxSurge
restriction, the cluster would temporarily contain twice as many Pods as usual while this operation is in progress.
maxUnavailable
: Refers to the number of Pods that can be unavailable out of the total number of Pods in the currently applied specification. A Pod is defined unavailable when it is not ready from a Kubernetes perspective.
The operator only tries to apply these constraints when a new specification is being applied. It is possible that the cluster state does not conform to the constraints at the beginning of the operation due to external factors. The operator will attempt to get to the desired state by adding or removing Pods as necessary while ensuring that the constraints are still satisfied.
For example, if a new specification defines a larger cluster with maxUnavailable: 0
, the operator creates the missing Pods according to the best practices. Similarly, if a new specification defines a smaller cluster with maxSurge: 0
, the operator safely removes the unnecessary Pods.
Specify changeBudget
editFor both maxSurge
and maxUnavailable
you can specify the following values:
-
null
- The default value is used. - non-negative - The value is used as is.
- negative - The value is unbounded.
Default behavior
editWhen updateStrategy
is not present in the specification, it defaults to the following:
spec: updateStrategy: changeBudget: maxSurge: -1 maxUnavailable: 1
maxSurge
is unbounded: This means that all the required Pods are created immediately.
maxUnavailable
defaults to 1
: This ensures that the cluster has no more than one unavailable Pod at any given point in time.
Caveats
edit-
With both
maxSurge
andmaxUnavailable
set to0
, the operator cannot bring down an existing Pod nor create a new Pod. -
Due to the safety measures employed by the operator, certain
changeBudget`s might prevent the operator from making any progress . For example, with `maxSurge
set to 0, you cannot remove the last data node from onenodeSet
and add a data node to a differentnodeSet
. In this case, the operator cannot create the new node becausemaxSurge
is 0, and it cannot remove the old node because there are no other data nodes to migrate the data to. -
For certain complex configurations, the operator might not be able to deduce the optimal order of operations necessary to achieve the desired outcome. If progress is blocked, you may need to update the
maxSurge
setting to a higher value than the theoretical best to help the operator make progress in that case.
If any of the above occurs, the operator generates logs to indicate that upscaling or downscaling are limited by maxSurge
or maxUnavailable
settings.