DOKK / manpages / debian 11 / perf-tools-unstable / perf-stat-hist-perf.8.en
perf-stat-hist(8) System Manager's Manual perf-stat-hist(8)

perf-stat-hist - histogram summary of tracepoint values. Uses Linux perf_events.

perf-stat-hist [-h] [-b buckets|-P power] [-m max] tracepoint variable [seconds]

This is a proof-of-concept showing in-kernel histograms using Linux perf_events (aka the "perf" command), on older kernels where perf_events does not have this native capability.

These histograms show the distribution of variable, allowing details including multiple modes and outliers to be studied.

This uses multiple counting tracepoints with different filters, one for each histogram bucket. While this is summarized in-kernel, the use of multiple tracepoints does add addiitonal overhead. Hopefully, in the future this this functionality will be provided in an efficient way from perf_events itself, at which point this tool can be deleted or rewritten.

Linux perf_events: add linux-tools-common, run "perf", then add any additional packages it requests. Also uses awk.

Usage message.
Specify a list of bucket points for the histogram as a string (eg, "10 500 1000"). The histogram will include buckets for less-than the minimum, and greater-than-or-equal-to the maximum. If a single value is specified, two statistics only are gathered: for less-than and for greater-than-or-equal-to. The overhead is relative to the number of buckets, so only specifying a single value costs the lowest overhead.
Power for power-of histogram. By default, a power-of-4 histogram is created. This and the -b option are exclusive.
Max value for power-of histograms.
Tracepoint specification. Eg, syscalls:sys_enter_read.
The tracepoint variable name to summarize. To see what are available, cat the format file under /sys/kernel/debug/tracing/events/*/*/format.
Number of seconds to trace. If not specified, this runs until Ctrl-C.

# perf-stat-hist syscalls:sys_enter_read count
# perf-stat-hist syscalls:sys_exit_read ret
# perf-stat-hist syscalls:sys_exit_read ret 10
# perf-stat-hist net:net_dev_xmit len
perf-stat-hist -P 10 syscalls:sys_exit_read ret
perf-stat-hist -P 2 -m 1024 syscalls:sys_exit_read ret
perf-stat-hist -b "10 50 100 5000" syscalls:sys_exit_read ret
perf-stat-hist -b 10 syscalls:sys_exit_read ret

Range of the histogram bucket, in units of the variable specified.
Number of occurrences (tracepoint events) of the variable in this range.
ASCII histogram representation of the Count column.

While the counts are performed in-kernel, there is one tracepoint used per histogram bucket, so the overheads are higher than usual (relative to the number of buckets) than function counting using perf stat. The lowest overhead is when -b is used to specify one bucket only, bifurcating statistics.

This is from the perf-tools collection.

https://github.com/brendangregg/perf-tools

Also look under the examples directory for a text file containing example usage, output, and commentary for this tool.

Linux

Unstable - in development.

Brendan Gregg

perf(1)

2014-07-07 USER COMMANDS