Exercise - Prove microservice resilience in Kubernetes
One of the benefits of Kubernetes is the support for declarative configuration management. The services you define in the configuration files are retained at all costs.
This means that if there's a failure, Kubernetes automatically restarts the services that were running before the failure.
Let's see this resilience in action by deleting the storefrontend
pod and then verifying that Kubernetes restarted it.
First, in the TERMINAL on the codespace, run
kubectl get pods
, and note the name, including the random string, of thestorefrontend
pod. Here's an example output:@user-name /workspaces/eShopLite % kubectl get pods NAME READY STATUS RESTARTS AGE productsbackend-7445bdb5c9-pnpk6 1/1 Running 0 31m storefrontend-5b6cc765c4-hjpx4 1/1 Running 0 63m
Now, delete the
storefrontend
pod by using thekubectl delete
command. You need to specify the full name of the pod, including the random string.kubectl delete pod storefrontend-5b6cc765c4-hjpx4
You receive a message immediately stating that the pod was deleted.
Because Kubernetes maintains the system state as declared in the configuration files, it immediately starts up another pod instance. You can verify that by running
kubectl get pods
.@user-name /workspaces/eShopLite % kubectl get pods NAME READY STATUS RESTARTS AGE productsbackend-7445bdb5c9-pnpk6 1/1 Running 0 31m storefrontend-5b6cc765c4-vwmv8 1/1 Running 0 7s
Notice that the random string following the
storefrontend
name is changed, indicating that the pod is a new instance. Also the AGE value is considerably less as well.
In this exercise, you learned how Kubernetes automatically maintains declared system state, even if there's a failure.