You can use Service Mesh (ASM) to send a copy of traffic destined for a service to a mirrored service. This topic describes how to configure mirroring.
Prerequisites
The preparations are completed, and the helloworld and sleep services are deployed. For more information, see Preparations.
Procedure
Check whether the service configurations take effect.
Use kubectl to connect to the Container Service for Kubernetes (ACK) cluster based on the information in the kubeconfig file, and then run the following command to enable bash for the sleep service:
kubectl exec -it deploy/sleep -- sh
Run the following command to send a request to the helloworld service:
curl helloworld:5000/hello
Expected output:
Hello version: v2, instance: helloworld-v2-6b96c5684-4**** Hello version: v1, instance: helloworld-v1-6d77f4c4cf-p****
The expected output is that helloworld-v1 or helloworld-v2 randomly responds to the request.
Configure a traffic rule for the helloworld service, configure helloworld-v1 to receive and respond to requests, and mirror the requests to helloworld-v2.
Use the following content to configure a destination rule. For more information, see Manage destination rules.
apiVersion: networking.istio.io/v1beta1 kind: DestinationRule metadata: name: helloworld namespace: default spec: host: helloworld subsets: - labels: version: v1 name: v1 - labels: version: v2 name: v2
Use the following content to create a virtual service. For more information, see Manage virtual services.
apiVersion: networking.istio.io/v1beta1 kind: VirtualService metadata: name: helloworld-vs namespace: default spec: hosts: - helloworld http: - mirror: host: helloworld subset: v2 route: - destination: host: helloworld subset: v1
Check whether the configurations take effect.
Use kubectl to connect to the ACK cluster based on the information in the kubeconfig file, and then run the following command to enable bash for the sleep service:
kubectl exec -it deploy/sleep -- sh
Run the following command to send a request to the helloworld service:
curl helloworld:5000/hello
The expected output is always that helloworld-v1 responds to the request.
Hello version: v1, instance: helloworld-v1-6d77f4c4cf-p****
View the topology of the service. For more information, see Use Mesh Topology to view the topology of an application.
Expected output: The request is copied to helloworld-v2.