Using top ebpf
The top ebpf gadget is used to visualize the usage and performance of eBPF programs.
On Kubernetes
This guide will let you run another gadget (we're using top file
in this example) and see its metrics
using top ebpf
.
So first, start top ebpf
in a terminal. You should see something like:
$ kubectl gadget top ebpf
K8S.NODE PROGID TYPE NAME PID COMM RUNTIME RUNCOUNT MAPMEMORY MAPCOUNT
minikube 503 Tracing ig_top_ebpf_it 573222 gadgettracerman 54.09µs 1069 12B 1
minikube 187 CGroupDevice 2.292µs 1 0B 0
minikube 13 CGroupSKB 0s 0 0B 0
...
The output should already contain the top ebpf
gadget itself.
Now, in a second terminal, start top file
on the gadget namespace to get some output.
$ kubectl gadget top file -n gadget
K8S.NODE K8S.NAMESPACE K8S.PODNAME K8S.CONTAINERNAME PID COMM READS WRITES R_KB W_KB T FILE
minikube gadget gadget-k2mvp gadget 575955 runc:[2:INIT] 1 0 0 0 R cap_last_cap
minikube gadget gadget-k2mvp gadget 575955 runc:[2:INIT] 2 0 8 0 R group
minikube gadget gadget-k2mvp gadget 575955 gadgettracerman 2 0 8 0 R UTC
...
While the top file
gadget is still running, go back to the first terminal.
Some eBPF programs of type Kprobe
should pop up, including their runtime and run count in the current interval
(default is 1s):
$ kubectl gadget top ebpf
K8S.NODE PROGID TYPE NAME PID COMM RUNTIME RUNCOUNT MAPMEMORY MAPCOUNT
minikube 506 Kprobe ig_topfile_rd_e 573222 gadgettracerman 824.589µs 2076 40.95MiB 4
minikube 505 Tracing ig_top_ebpf_it 573222 gadgettracerman 47.171µs 1103 12B 1
minikube 507 Kprobe ig_topfile_wr_e 573222 gadgettracerman 609.645µs 836 40.95MiB 4
minikube 187 CGroupDevice 4.417µs 2 0B 0
minikube 13 CGroupSKB 0s 0 0B 0
minikube 8 CGroupSKB 0s 0 0B 0
...
So in this case for example, in the past second vfs_write_entry
has been called 647 times, which took 614.455µs.
The program references 4 maps that have a total maximum size of 40.953 MB (see below for more information on MapMemory).
If you want to get the cumulative runtime and run count of the eBPF programs starting from the beginning of the trace,
you can call the gadget with the columns option and specify the cumulruntime and cumulruncount columns.
Combined with the --sort cumulruntime
and --timeout 60
parameters, you can for example measure the time spent
over a minute:
$ kubectl-gadget top ebpf -o columns=k8s.node,progid,type,name,pid,comm,cumulruntime,cumulruncount --sort cumulruntime --timeout 60
K8S.NODE PROGID TYPE NAME PID COMM CUMULRUNTIME CUMULRUNCOUNT
minikube 509 Tracing ig_top_ebpf_it 573222 gadgettracerman 1.265693ms 15879
minikube 187 CGroupDevice 40.795µs 48
minikube 256 CGroupDevice 5.834µs 2
minikube 13 CGroupSKB 0s 0
minikube 7 CGroupSKB 0s 0
minikube 8 CGroupSKB 0s 0
...
With ig
Run any tool that uses eBPF, for instance, iovisor/bcc execsnoop
: from BCC. Please note that it can be run on the host directly.
$ sudo ./execsnoop
PCOMM PID PPID RET ARGS
runc 167851 142428 0 /usr/bin/runc --version
docker-init 167857 142428 0 /usr/bin/docker-init --version
...
Start the top ebpf
gadget in another terminal. It'll show the programs installed by the tool above.
$ sudo ig top ebpf
PROGID TYPE NAME PID COMM RUNTIME RUNCOUNT MAPMEMORY MAPCOUNT
1102 Tracing ig_top_ebpf_it 167925 ig 299.054