Join Linux nodes¶
MKE allows you to add or remove nodes from your cluster as your needs change over time.
Because MKE leverages the clustering functionality provided by Mirantis Container Runtime (MCR), you use the docker swarm join command to add more nodes to your cluster. When you join a new node, MCR services start running on the node automatically.
You can add both Linux manager and worker nodes to your cluster.
Join a node to the cluster¶
Important
Prior to adding a node that was previously a part of the same MKE cluster or a different one, you must run the following command to remove any stale MKE volumes:
docker volume rm `docker volume list --filter name=ucp* -q`
Next, run the following command to verify the removal of the stale volumes:
docker volume list --filter name=ucp*
Log in to the MKE web UI.
In the left-side navigation panel, navigate to Shared Resources > Nodes.
Click Add Node.
Select Linux for the node type.
Select either Manager or Worker, as required.
Optional. Select Use a custom listen address to specify the address and port where the new node listens for inbound cluster management traffic.
Optional. Select Use a custom advertise address to specify the IP address that is advertised to all members of the cluster for API access.
Copy the displayed command, which looks similar to the following:
docker swarm join --token <token> <mke-node-ip>
Use SSH to log in to the host that you want to join to the cluster.
Run the docker swarm join command captured previously.
The node will display in the Shared Resources > Nodes page.
Pause or drain a node¶
Note
You can pause or drain a node only with swarm workloads.
You can configure the availability of a node so that it is in one of the following three states:
- Active
The node can receive and execute tasks.
- Paused
The node continues running existing tasks, but does not receive new tasks.
- Drained
Existing tasks are stopped, while replica tasks are launched in active nodes. The node does not receive new tasks.
To pause or drain a node:
Log in to the MKE web UI.
In the left-side navigation panel, navigate to Shared Resources > Nodes and select the required node.
In the Details pane, click Configure and select Details to open the Edit Node page.
In the upper right, select the Edit Node icon.
In the Availability section, click Active, Pause, or Drain.
Click Save.
Promote or demote a node¶
You can promote worker nodes to managers to make MKE fault tolerant. You can also demote a manager node into a worker node.
Log in to the MKE web UI.
In the left-side navigation panel, navigate to Shared Resources > Nodes and select the required node.
In the upper right, select the Edit Node icon.
In the Role section, click Manager or Worker.
Click Save and wait until the operation completes.
Navigate to Shared Resources > Nodes and verify the new node role.
Note
If you are load balancing user requests to MKE across multiple manager nodes, you must remove these nodes from the load-balancing pool when demoting them to workers.
Remove a node from the cluster¶
To remove an inaccessible worker node or one that is down:
Log in to the MKE web UI.
In the left-side navigation panel, navigate to Shared Resources > Nodes and select the required node.
In the upper right, select the vertical ellipsis and click Remove.
When prompted, click Confirm.
To remove an inactive worker node:
Log in to the MKE web UI.
In the left-side navigation panel, navigate to Shared Resources > Nodes and select the required node.
Drain the node, to ensure that the workload is scheduled to another node.
Click the vertical ellipsis in the upper right and select Force Remove.
When prompted, click Confirm.
To remove a manager node:
Verify that all nodes in the cluster are healthy.
Warning
Do not remove the manager node if all nodes are not healthy.
Remove the newly-demoted worker from the cluster, as described in the preceding steps.