In this chapter we will learn how to test the resiliency of an application by injecting systematic faults. Before we start, we will need to reset the virtual services.
Using Meshery, navigate to the Istio management page:
default
in the Namespace
field.Apply Custom Configuration
card and paste the configuration below.Config:
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
name: reviews
spec:
hosts:
- reviews
http:
- route:
- destination:
host: reviews
subset: v2
To start, we will inject a 7s delay for accessing the ratings service for a user jason
. reviews v2 service has a 10s hard-coded connection timeout for its calls to the ratings service configured globally.
Using Meshery, navigate to the Istio management page:
default
in the Namespace
field.Apply Custom Configuration
card and paste the configuration below.This will update the existing virtual service definition for ratings to inject a delay for user jason
to access the ratings V1.
In a few, we should be able to verify the virtual service by using the command below:
kubectl get virtualservice ratings -o yaml
Config:
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
name: ratings
spec:
hosts:
- ratings
http:
- fault:
delay:
fixedDelay: 7s
percentage:
value: 100
match:
- headers:
end-user:
exact: jason
route:
- destination:
host: ratings
subset: v1
- route:
- destination:
host: ratings
subset: v1
Now we login to /productpage
as user jason
and observe that the page loads but because of the induced delay between services the reviews section will show :
Error fetching product reviews! Sorry, product reviews are currently unavailable for this book.
If you logout or login as a different user, the page should load normally without any errors.
In this section, , we will introduce an HTTP abort to the ratings microservices for user jason
.
Using Meshery, navigate to the Istio management page:
default
in the Namespace
field.Apply Custom Configuration
card and paste the configuration below.This will update the existing virtual service definition for ratings to inject a HTTP abort for user jason
to access the ratings V1.
In a few, we should be able to verify the virtual service by using the command below:
kubectl get virtualservice ratings -o yaml
Config:
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
name: ratings
spec:
hosts:
- ratings
http:
- fault:
abort:
httpStatus: 500
percentage:
value: 100
match:
- headers:
end-user:
exact: jason
route:
- destination:
host: ratings
subset: v1
- route:
- destination:
host: ratings
subset: v1
Now we login to /productpage
as user jason
and observe that the page loads without any new delays but because of the induced fault between services the reviews section will show:
Ratings service is currently unavailable
.
Verify the fault injection by logging out (or logging in as a different user), the page should load normally without any errors.
kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yaml
kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml
kubectl apply -f samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml
kubectl apply -f samples/bookinfo/networking/virtual-service-ratings-test-abort.yaml