ch18 lab

Setup

Connect to the control plane node:

vagrant ssh kiamol-control

Sample Solution

You take a node out of service by draining it, which reschedules the Pods - you need the DaemonSet flag so the system components are ignored:

kubectl drain kiamol-node --ignore-daemonsets

There is also the kubectl cordon command which marks the node so it won't have any new Pods scheduled, but that doesn't remove the existing Pods.

When you're done working on the node you can bring it back into service by uncordoning it:

kubectl uncordon kiamol-node

That marks the node as available for work, but Kubernetes doesn't automatically reschedule existing workloads so the node won't start any application Pods.

You can rebalance the API Pods by restarting the rollout:

kubectl rollout restart deploy apod-api

Teardown

You can delete all of the Vagrant VMs with:

vagrant destroy