This section covers the following topics:

Node Options Available for Each Cluster Creation Option

The following table lists which node options are available for each type of cluster in Rancher. Click the links in the Option column for more detailed information about each feature.

* Delete option accessible via View API

Node pools are available when you provision Rancher-launched Kubernetes clusters on nodes that are

Clusters provisioned using one of the node pool options can be scaled up or down if the node pool is edited.

A node pool can also automatically maintain the node scale that’s set during the initial cluster provisioning if This scale determines the number of active nodes that Rancher maintains for the cluster.

Rancher uses node templates to replace nodes in the node pool. Each node template uses cloud provider credentials to allow Rancher to set up the node in the infrastructure provider.

Nodes Provisioned by Hosted Kubernetes Providers

Options for managing nodes hosted by a Kubernetes provider are somewhat limited in Rancher. Rather than using the Rancher UI to make edits such as scaling the number of nodes up or down, edit the cluster directly.

Registered Nodes

Although you can deploy workloads to a registered cluster using Rancher, you cannot manage individual cluster nodes. All management of imported cluster nodes must take place outside of Rancher.

Managing and Editing Individual Nodes

Editing a node lets you:

  • Change its description
  • Add labels
  • Add/Remove

To manage individual nodes, browse to the cluster that you want to manage and then select Nodes from the main menu. You can open the options menu for a node by clicking its icon ().

Viewing a Node in the Rancher API

Select this option to view the node’s .

Deleting a Node

Use Delete to remove defective nodes from the cloud provider.

When you the delete a defective node, Rancher can automatically replace it with an identically provisioned node if the node is in a node pool and

Scaling Nodes

For nodes hosted by an infrastructure provider, you can scale the number of nodes in each by using the scale controls. This option isn’t available for other cluster types.

SSH into a Node Hosted by an Infrastructure Provider

For , you have the option of downloading its SSH key so that you can connect to it remotely from your desktop.

  1. Find the node that you want to remote into. Select ⋮ > Download Keys.

    Step Result: A ZIP file containing files used for SSH is downloaded.

  2. Extract the ZIP file to any location.

  3. Open Terminal. Change your location to the extracted ZIP file.

  4. Enter the following command:

Cordoning a Node

Cordoning a node marks it as unschedulable. This feature is useful for performing short tasks on the node during small maintenance windows, like reboots, upgrades, or decommissions. When you’re done, power back on and make the node schedulable again by uncordoning it.

Draining a Node

Draining is the process of first cordoning the node, and then evicting all its pods. This feature is useful for performing node maintenance (like kernel upgrades or hardware maintenance). It prevents new pods from deploying to the node while redistributing existing pods so that users don’t experience service interruption.

  • For pods with a replica set, the pod is replaced by a new pod that will be scheduled to a new node. Additionally, if the pod is part of a service, then clients will automatically be redirected to the new pod.

  • For pods with no replica set, you need to bring up a new copy of the pod, and assuming it is not part of a service, redirect clients to it.

You can drain nodes that are in either a or active state. When you drain a node, the node is cordoned, the nodes are evaluated for conditions they must meet to be drained, and then (if it meets the conditions) the node evicts its pods.

However, you can override the conditions draining when you initiate the drain. You’re also given an opportunity to set a grace period and timeout value.

There are two drain modes: aggressive and safe.

  • Aggressive Mode

    In this mode, pods won’t get rescheduled to a new node, even if they do not have a controller. Kubernetes expects you to have your own logic that handles the deletion of these pods.

    Kubernetes also expects the implementation to decide what to do with pods using emptyDir. If a pod uses emptyDir to store local data, you might not be able to safely delete it, since the data in the emptyDir will be deleted once the pod is removed from the node. Choosing aggressive mode will delete these pods.

  • Safe Mode

    If a node has standalone pods or ephemeral data it will be cordoned but not drained.

    Grace Period

The timeout given to each pod for cleaning things up, so they will have chance to exit gracefully. For example, when pods might need to finish any outstanding requests, roll back transactions or save state to some external storage. If negative, the default value specified in the pod will be used.

Timeout

If there’s any error related to user input, the node enters a cordoned state because the drain failed. You can either correct the input and attempt to drain the node again, or you can abort by uncordoning the node.

If the drain continues without error, the node enters a draining state. You’ll have the option to stop the drain when the node is in this state, which will stop the drain process and change the node’s state to .

Once drain successfully completes, the node will be in a state of drained. You can then power off or delete the node.

Labeling a Node to be Ignored by Rancher

Some solutions, such as F5’s BIG-IP integration, may require creating a node that is never registered to a cluster.

Since the node will never finish registering, it will always be shown as unhealthy in the Rancher UI.

In that case, you may want to label the node to be ignored by Rancher so that Rancher only shows nodes as unhealthy when they are actually failing.

You can label nodes to be ignored by using a setting in the Rancher UI, or by using kubectl.

Labeling Nodes to be Ignored with the Rancher UI

To add a node that is ignored by Rancher,

  1. From the Global view, click the Settings tab.
  2. Go to the ignore-node-name setting and click ⋮ > Edit.
  3. Enter a name that Rancher will use to ignore nodes. All nodes with this name will be ignored.
  4. Click Save.

Result: Rancher will not wait to register nodes with this name. In the UI, the node will displayed with a grayed-out status. The node is still part of the cluster and can be listed with .

If the setting is changed afterward, the ignored nodes will continue to be hidden.

Labeling Nodes to be Ignored with kubectl

To add a node that will be ignored by Rancher, use kubectl to create a node that has the following label:

    Result: If you add the node to a cluster, Rancher will not attempt to sync with this node. The node can still be part of the cluster and can be listed with kubectl.

    If the label is added before the node is added to the cluster, the node will not be shown in the Rancher UI.

    If the label is added after the node is added to a Rancher cluster, the node will not be removed from the UI.

    If you delete the node from the Rancher server using the Rancher UI or API, the node will not be removed from the cluster if the is listed in the Rancher settings under ignore-node-name.