Profile applicability: Level 2
Node auto-upgrade keeps nodes at the current Kubernetes and OS security patch level
to mitigate known vulnerabilities.
Node auto-upgrade helps you keep the nodes in the cluster or node pool up to date
with the latest stable patch version of Kubernetes as well as the underlying node
operating system. Node auto-upgrade uses the same update mechanism as manual node
upgrades.
Node pools with node auto-upgrade enabled are automatically scheduled for upgrades
when a new stable Kubernetes version becomes available. When the upgrade is performed,
the Node pool is upgraded to match the current cluster master version.
From a security perspective, this has the benefit of applying security updates automatically
to the Kubernetes Engine when security fixes are released.
NoteNode auto-upgrade is enabled by default. Even if a cluster has been created with node
auto-repair enabled, this only applies to the default Node pool. Subsequent node pools
do not have node auto-upgrade enabled by default.
|
Impact
Enabling node auto-upgrade does not cause the nodes to upgrade immediately. Automatic
upgrades occur at regular intervals at the discretion of the Kubernetes Engine team.
To prevent upgrades occurring during a peak period for the cluster, a maintenance
window should be defined.
A maintenance window is a four-hour timeframe that can be chosen, during which automatic
upgrades should occur. Upgrades can occur on any day of the week, and at any time
within the timeframe. To prevent upgrades from occurring during certain dates, a maintenance
exclusion should be defined. A maintenance exclusion can span multiple days.
NoteAs part of the GKE node Auto-Upgrade process, the node is recreated. When a node is
created, it automatically receives the latest version of the node image. For COS images,
this is the primary OS upgrade mechanism.
|
Audit
Using Google Cloud Console:
- Go to Kubernetes Engine by visiting: Google Cloud Console Kubernetes Engine page.
- From the list of clusters, select the desired cluster.
- For each Node pool, view the Node pool Details pane and ensure that under the 'Management' heading, 'Auto-upgrade' is set to 'Enabled'.
Using Command Line:
To check the existence of node auto-upgrade for an existing cluster's Node pool, first
define 4 variables for Node Pool, Cluster Name, Location and Project and then run
the following command:
gcloud container node-pools describe $POOL_NAME --cluster $CLUSTER_NAME --location $LOCATION --project $PROJECT_ID --format json | jq '.management'
Ensure the output of the above command has JSON key attribute
autoUpgrade set to true:{ "autoUpgrade": true }
If node auto-upgrade is disabled, the output of the above command will not contain
the
autoUpgrade entry.Remediation
Using Google Cloud Console:
- Go to Kubernetes Engine by visiting: Google Cloud Console Kubernetes Engine page.
- Select the Kubernetes cluster containing the node pool for which auto-upgrade is disabled.
- Select the Node pool by clicking on the name of the pool.
- Navigate to the Node pool details pane and click EDIT.
- Under the Management heading, check the Enable auto-upgrade box.
- Click SAVE.
- Repeat steps 2-6 for every cluster and node pool with auto-upgrade disabled.
Using Command Line:
To enable node auto-upgrade for an existing cluster's Node pool, run the following
command:
gcloud container node-pools update <node_pool_name> --cluster <cluster_name> --location <location> --enable-autoupgrade
