Skip to content

Latest commit

 

History

History
45 lines (33 loc) · 1.7 KB

README.md

File metadata and controls

45 lines (33 loc) · 1.7 KB

bpf-docker

bpf-docker is an image to help you run BPF and profiling programs in Docker.

Easily incorporate LinuxKit kernel headers, BTF, and debugfs into your container. As a result, you can now execute BPF programs within Docker Desktop for Mac/Windows(WSL) and Linux.

For profiling analysis would highly recommend reading perf and eBPF, as well as this excellent post from Netflix Performance Engineering team for their investigation process in 60 seconds.

60 second analysis

uptime
dmesg | tail
vmstat 1
mpstat -P ALL 1
pidstat 1
iostat -xz 1
free -m
sar -n DEV 1
sar -n TCP,ETCP 1
top

Usage

Consult bpftrace documentation for additional tracing,

docker run -it --rm \ 
  --privileged \ 
  -v /lib/modules:/lib/modules:ro \ 
  -v /etc/localtime:/etc/localtime:ro \ 
  --pid=host \ 
  bpftrace -e 'tracepoint:raw_syscalls:sys_enter { @[comm] = count(); }'

Note: /lib/modules probably doesn't exist on your mac host, so Docker will map the volume in from the linuxkit host VM.

Note: you need to make sure the image matches the architecture of the host. For example, if you are running on a M1/M2 Mac, you need to use arm64 image.

set flag KERNEL_VERSION=5.15.110-arm64

Maintenance

Docker publishes their for-desktop kernel's on Docker hub you may need to update the Dockerfile for the latest kernel that matches your linuxkit host VM.