Skip to content

eBPF

Requirements

Prerequisites here
eBPF in this context only runs on Kubernetes with modern Linux kernel based containers.

Official Documentation here

Please read the official documentation thoroughly before proceeding. There are many combinations possible with eBPF installation and this workshop only showcases one of them.

What is eBPF?

eBPF describes software that runs inside the Linux kernel and can extend its functionality. For Observability purposes, the loaded module is capturing telemetry related to observability such as system calls, network activity, kernel function calls etc.

The Coralogix implementation loads an eBPF agent into the kernels of running containers that exports the eBPF related telemetry and converts it to OpenTelemetry compatiable spans. eBPF spans do not provide traces since they don't have a trace ID. Please carefully read official Coralogix Documenttion above for more detail.

Instructions

This workshop is designed to add the eBPF agent to an existing installation of the Coralogix OpenTelemetry helm chart and then deploy simple applications in Python, Node, .NET, and Java to demonstrate the spans and APM capabilities available with eBPF.

Step 1 - Install the OpenTelemetry Collector on your k8s cluster

Easy Coralogix instructions for Complete Observability are here

Step 2 - Clone Repo

git clone https://github.com/coralogix/workshops

Step 3 - Change to eBPF Directory

cd workshops/workshops/otel/ebpf

Step 4 - Override the OpenTelemetry Helm Chart to add the eBPF Agent

Edit ebpf.yaml and update the globals for your domain and cluster name then:

source deploy-ebpf.sh

Step 5 - Deploy Example Applications

source deploy-all-examples.sh

Step 6 - Study The Results

Note in Coralogix->Explore->Traces that the requests are only one span deep, and that the TraceID is not truly utilized for connecting spans. Also note the otel.library.name of coralogix-ebpf-agent.

Coralogix->APM shows the working service catalog.

Other parts of the Kubernetes system are being traced as well- these can be filtered following instructions in the documentation above.

Step 7 - Cleanup

source delete-all-examples.sh
helm rollback otel-coralogix-integration