This program summarizes scheduler queue length as a histogram, and can also show run queue occupancy. It works by sampling the run queue length on all CPUs at 99 Hertz.
This tool can be used to identify imbalances, eg, when processes are bound to CPUs causing queueing, or interrupt mappings causing the same.
Since this uses BPF, only the root user can use this tool.
CONFIG_BPF and bpftrace.
- Trace CPU run queue length system wide, printing a histogram on Ctrl-C:
- 1st, 2nd
The run queue length is shown in the first field (after "[").
A column showing the count of samples in for that length.
This is an ASCII histogram representing the count column.
This samples scheduler structs at 99 Hertz across all CPUs. Relatively, this is a low rate of events, and the overhead of this tool is expected to be near zero.
This is from bpftrace.
Also look in the bpftrace distribution for a companion _examples.txt file containing example usage, output, and commentary for this tool.
This is a bpftrace version of the bcc tool of the same name. The bcc tool may provide more options and customizations.
Unstable - in development.
runqlat(8), mpstat(1), pidstat(1), uptime(1)
bcc-cpuunclaimed(8), bcc-runqlat(8), bcc-runqslower(8), runqlat(8).