biosnoop.bt - Man Page
Block I/O tracing tool, showing per I/O latency. Uses bpftrace/eBPF.
Synopsis
biosnoop.bt
Description
This is a basic block I/O (disk I/O) tracing tool, showing each I/O event along with the issuing process ID, and the I/O latency. This can be used to investigate disk I/O performance issues.
This tool currently works by dynamic tracing of the blk_account*() kernel functions, which will need updating to match any changes to these functions in future kernels versions.
Since this uses BPF, only the root user can use this tool.
Requirements
CONFIG_BPF and bpftrace.
Examples
- Trace block I/O events, printing per-line summaries:
# biosnoop.bt
Fields
- TIME
Time of the I/O completion, in milliseconds since program start.
- COMM
Issuing process name. This often identifies the issuing application process, but I/O may be initiated from kernel threads only.
- PID
Issuing process ID. This often identifies the issuing application process, but I/O may be initiated from kernel threads only.
- ARGS
Process name and arguments (16 word maximum).
Overhead
Since block device I/O usually has a relatively low frequency (< 10,000/s), the overhead for this tool is expected to be negligible. For high IOPS storage systems, test and quantify before use.
Source
This is from bpftrace.
https://github.com/bpftrace/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 provides more fields.
OS
Linux
Stability
Unstable - in development.
Author
Brendan Gregg
See Also
Referenced By
biolatency.bt(8), biostacks.bt(8), bitesize.bt(8), mdflush.bt(8), sslsnoop.bt(8), writeback.bt(8).