Logs with Loki

Logs in Fission

Fission has a few core services running and these core services handle user functions. The logs from both are useful in debugging the functions.

A good log monitoring solution can be useful to make full use of these logs.

Grafana Loki

Loki is a horizontally-scalable, highly-available, multi-tenant log aggregation system inspired by Prometheus. The main components are a client to fetch the logs, an aggregator, and a visualizing tool (Grafana).

The stack supports multiple clients, for the case here we will use Promtail which is the recommended client when using the stack in Kubernetes. Here is a quick overview of components that make up the Loki platform:

  • Loki - Loki is a horizontally scalable, highly available, multi-tenant log aggregation system inspired by Prometheus.
  • Promtail - Promtail is the client which fetches and forwards the logs to Loki. It is a good fit for Kubernetes as it automatically fetches metadata such as pod labels.
  • Grafana - A visualization tool that supports Loki as a data source.

The stack is depicted briefly in the below image

Loki-Grafana stack

Setting up

There are different ways and configurations to install the complete stack. For this case, we’ll use Helm.


Install Loki and Promtail

From a terminal, run the following commands to add the Loki repo and then install Loki

$ helm repo add loki https://grafana.github.io/loki/charts
$ helm repo update
$ helm upgrade --install loki loki/loki-stack

This will install Loki in the default namespace. Check if there’re pods running for Loki and Promtail.

Install Grafana

Similarly, to install Grafana, run the following commands from a terminal.

$ helm repo add grafana https://grafana.github.io/helm-charts
$ helm repo update
$ helm upgrade --install fission-logs grafana/grafana -n grafana

This will install Grafana in the grafana namespace, with helm release name as fission-logs

Accessing Grafana UI

The installation above creates a Service in grafana namespace. To access this, you can use Kubernetes port forwarding.

$ kubectl --namespace grafana port-forward svc/fission-logs-grafana 3000:80

Adding Loki as a data source in Grafana

Clicking on the Settings icon in the left pane will bring up a menu, click on Data Sources. Clicking on Add Data Source and select Loki. Under HTTP, in the URL field, put the ClusterIP followed by port number. You can get the ClusterIP using

$ kubectl get svc  -l "app=loki" -o jsonpath="{.items[0].spec.clusterIP}"

For example, if the ClusterIP is the value to put is Click on Save and Test and there should be a notification of the data source added successfully.

Running Log Queries

From the options in left pane, navigate to Explore. Here you can run log queries using LogQL. Since Loki auto scrapes labels, there will be example log queries presented. There also will be list of log labels that you can select from.

You can run queries for Fission components such as:

  • All logs from Fission Router {svc="router"}
  • All logs from Fission Router that have “error” in the statement. {svc="router"} |= "error"

Loki is great for performing metrics over the logs, for example:

  • Count of all logs in Fission Router with “error” over span of 5 mins count_over_time({svc="router"} |= "error" [5m]).

Fission Logs Dashboard

Grafana provides a great way to build visual dashboards by aggregating queries. These dashboards are a set of individual panels each showing visuals of some queries. Metrics over this logs can be seen in real time. The dashboards are also easily shareable.

Multiple panel with queries over Fission can be put together to get overall view of Fission components as well the Functions running within. An exported JSON of one such dashboard can be found here. This dashboard shows log metrics from all the major components of Fission.

Once imported, the dashboard will look similar to below image.

Loki-Grafana dashboard

Watch the same location for more dashboards which will be added over time.

Last modified October 27, 2020: Markdown lint reformat (#221) (8fc8f1c)