Compute Infrastructure

Obtain and visualise uniform metrics, logs, traces across microservices using Istio

Share this post:

In this blog post, you will learn how to setup Istio on your Kubernetes cluster using Helm or Kubernetes-YAML and you will be using add-ons like Jaeger, Prometheus, Grafana, & Weavescope to collect, query and visualize metrics, logs & traces (in-depth telemetry) for your microservices.

If you have read our previous blog post about Modernizing your old JPetStore app with containers, Kubernetes and AI, there is a hidden jewel (extension) in the jpetstore-kubernetes repository and it addresses one of the many capabilities of Istio, a service mesh.

Istio logo

What is Istio?

Istio is an open platform to connect, secure, and manage a network of microservices, also known as a service mesh, on cloud platforms such as Kubernetes in IBM® Cloud Kubernetes Service. With Istio, you can manage network traffic, load balance across microservices, enforce access policies, verify service identity, and more.

Istio addresses many of the challenges faced by developers and operators as monolithic applications transition towards a distributed microservice architecture. The term service mesh is often used to describe the network of microservices that make up such applications and the interactions between them. As a service mesh grows in size and complexity, it can become harder to understand and manage. Its requirements can include discovery, load balancing, failure recovery, metrics, and monitoring, and often more complex operational requirements such as A/B testing, canary releases, rate limiting, access control, and end-to-end authentication.

Setup Istio

You can install, setup and deploy Istio sidecars into your cluster in two ways

  1. Using Helm
  2. Using Kubernetes-YAML files

Once deployed and with the application responding to traffic, the graphs will start highlighting what’s happening under the covers.

Prometheus scrapes metrics from instrumented jobs, either directly or via an intermediary push gateway for short-lived jobs. It stores all scraped samples locally and runs rules over this data to either aggregate and record new time series from existing data or generate alerts. Grafana or other API consumers can be used to visualize the collected data.

Grafana Istio Dashboard

Following the steps in the respective README files, you can generate a service graph, visualise Cluster using Weave Scope, and also check distributed tracing with Jaeger.

Weavescope dashboard

Further learning…

Technical Offering Manager & Polyglot Programmer | IBM Cloud

More Compute Infrastructure stories
November 13, 2018

Infrastructure as Code: Chef, Ansible, Puppet, or Terraform?

Which is the most appropriate Infrastructure as Code tool: Terraform, Chef, Ansible, or Puppet? Alternatively, is the best option to use Terraform for orchestration and one of the others for configuration management?

Continue reading

November 9, 2018

Infrastructure as Code Accelerates Application Deployment

Who doesn't value rapidly deploying applications and environments, repeatable and consistent environment builds, and dev and test environments that mirror production? Treating Infrastructure as Code brings practices that have transformed application development in the last 10 years to infrastructure and services.

Continue reading

November 7, 2018

Deploy SSL Offload in Citrix NetScaler VPX/ADC Using IBM Cloud HSM

SSL Offload is a common requirement in many application deployments. At IBM Cloud, two powerful and flexible products can be combined for your SSL offload use cases: IBM Cloud Hardware Security Module (HSM) and Citrix NetScaler VPX/Application Delivery Controller (ADC).

Continue reading