istio101

Istio Hands-On


Project maintained by Harald-U Hosted on GitHub Pages — Theme by mattgraham

Getting Started - Prepare Your Environment ## Exercise 1 - Accessing your Kubernetes Cluster ## Exercise 2 - Installing Istio ## Exercise 3 - Deploy Guestbook with Istio Proxy ## Exercise 4 - Expose the service mesh with the Istio Ingress Gateway ## Exercise 5 - Telemetry ## Exercise 6 - Traffic Management ## Exercise 7 - Security


Exercise 4 - Expose the service mesh with the Istio Ingress Gateway

The components deployed on the service mesh by default are not exposed outside the cluster. External access to individual services so far has been provided by creating an external load balancer or node port on each service.

An Ingress Gateway resource can be created to allow external requests through the Istio Ingress Gateway to the backing services.

Expose the Guestbook app with Ingress Gateway

  1. Configure the guestbook default route with the Istio Ingress Gateway. The guestbook-gateway.yaml file is in this repository (istio101) in the workshop/plans directory.

     cd ../../plans
     kubectl create -f guestbook-gateway.yaml
    
  2. Get the EXTERNAL-IP of the Istio Ingress Gateway.

     kubectl get service istio-ingressgateway -n istio-system
    

    Output:

     NAME                   TYPE           CLUSTER-IP      EXTERNAL-IP     PORT(S)                                       AGE
     istio-ingressgateway   LoadBalancer   172.21.254.53    169.6.1.1       80:31380/TCP,443:31390/TCP,31400:31400/TCP    1m
     2d
    
  3. Make note of the external IP address that you retrieved in the previous step, as it will be used to access the Guestbook app in later parts of the course. Create an environment variable called $INGRESS_IP with your IP address.

    Example:

     export INGRESS_IP=169.6.1.1
    

Connect Istio Ingress Gateway to the IBM Cloud Kubernetes Service NLB Host Name

NLB host names are the DNS host names you can generate for each IBM Cloud Kubernetes deployment exposed with the Network LoadBalancer(NLB) service. These host names come with SSL certificate, the DNS registration, and health checks so you can benefit from them for any deployments that you expose via the NLB on IBM Cloud Kubernetes Service.

For example, you can run the IBM Cloud Kubernetes Service ALB, an API gateway of your choice, an Istio ingress gateway, and an MQTT server in parallel in your IBM Cloud Kubernetes Service cluster. Each one will have its own:

Let’s leverage this feature with Istio ingress gateway:

  1. Switch back the ibmcloud CLI to the IBM Lab account by logging in again:

     ibmcloud login
    
  2. From the account list, choose IBM as the Account (NOT your own)

  3. Create the NLB host with the Istio ingress gateway’s public IP address:

     ibmcloud ks nlb-dns create classic --cluster $MYCLUSTER --ip $INGRESS_IP
    
  4. List the NLB host names for your cluster:

     ibmcloud ks nlb-dns ls --cluster $MYCLUSTER
    

    Example output:

       
     Hostname                                                                                IP             Health Monitor   H.Monitor Status   
     istio1010bin09-0e3e0ef4c9c6d831e8aa6fe01f33bfc4-0000.eu-gb.containers.appdomain.cloud   141.125.94.2   None             created           istio1010bin09-0e3e0ef4c9c6d831e8aa6fe01f33bfc4-0000   default   
     istio1010bin09-0e3e0ef4c9c6d831e8aa6fe01f33bfc4-0001.eu-gb.containers.appdomain.cloud   141.125.94.6   None             pending           -                                                      default   
    

    Note: This list will contain two NLB host names. The first one would be the host name of the Kubernetes ingress, so watch for the correct IP address! (echo $INGRESS_IP)

  5. Make note of the NLB host name, as it will be used to access your Guestbook app in later parts of the course. Create an environment variable for it and test using curl or visit in your browser.

    Example:

     export NLB_HOSTNAME=istio1010bin09-0e3e0ef4c9c6d831e8aa6fe01f33bfc4-0001.eu-gb.containers.appdomain.cloud
    
     curl $NLB_HOSTNAME
    
  6. Enable health check of the NLB host for Istio ingress gateway:

     ibmcloud ks nlb-dns monitor configure --cluster $MYCLUSTER --nlb-host $NLB_HOSTNAME --type HTTP --description "Istio ingress gateway health check" --path "/healthz/ready" --port 15020 --enable
    
  7. Monitor the health check of the NLB host for Istio ingress gateway:

     ibmcloud ks nlb-dns monitor status --cluster $MYCLUSTER
    

    After waiting for a bit, you should start to see the health monitor’s status changed to Enabled.

    Example output:

        
     Hostname                                                                                IP          Health Monitor   H.Monitor Status   
     istio1010bin09-0e3e0ef4c9c6d831e8aa6fe01f33bfc4-0001.eu-gb.containers.appdomain.cloud   169.1.1.1   Enabled          Healthy
    

Congratulations! You extended the base Ingress features by providing a DNS entry to the Istio service.

You can now access the Guestbook app using the (somewhat complicated) URL of the NLB_HOSTNAME. In real life you would now map this URL to your own website URL.


Continue to Exercise 5 - Telemetry


Further Reading: