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
September 10, 2018

Analyzing Data with IBM Cloud SQL Query

In this article, we're going to give you an introduction to getting set up with IBM Cloud SQL Query and using its UI. Then, we'll compose and run queries in a Jupyter Notebook on Watson Studio with the SQL Query Python library and PixieDust.

Continue reading

August 28, 2018

Register for the Webinar: Building a Better Cloud with IBM and Intel Processors

Register now for the "Building a Better Cloud" webinar on September 6, 2018, to learn about how IBM Cloud bare metal servers with Intel Xeon Scalable processors enhance performance and security of mission-critical workloads.

Continue reading

August 27, 2018

Take the Day Off: Celebrating Labor Day with Kubernetes on the Job

This year, you can take Labor Day off, confident that IBM Cloud Kubernetes Service will be there for you. We'll manage the underlying Kubernetes service while you enjoy a much-needed a day off.

Continue reading