In this exercise we will learn how to test the resiliency of an application by injecting faults.
To test our guestbook application for resiliency, this exercise will test injecting different levels of delay when the user agent accessing the hello world service is mobile.
We can inject delays into the request.
kubectl apply -f istio/guestbook-ui-delay-vs.yaml
Browse to the Guestbook UI, and you'll see that the request is responding much slower!
We can also inject error responses, such as returning 503 from a service.
kubectl apply -f istio/guestbook-service-503.yaml
Visiting the Guestbook UI, and you'll see that it is now unable to retrieve any Guestbook messages. Luckily, the application has a graceful fallback to display a nice error message.
Remove the annoying 503 errors.
kubectl delete -f istio/guestbook-service-503.yaml
Then reset the Guestbook UI virtual service so that it routes all requests to V1.
kubectl apply -f istio/guestbook-ui-v1-vs.yaml
There are several circuit breaker rules you can apply in Istio:
- Retries
- Outlier Detection
- Connection pooling
Retries can be configured in the virtual service.
kubectl apply -f istio/guestbook-service-retry-vs.yaml
Outlier and connection pooling are configured in the destination rule.
kubectl apply -f istio/guestbook-service-dest.yaml
kubectl apply -f istio/guestbook-service-dest.yaml