DOKK / manpages / debian 10 / bpftrace / statsnoop.bt.8.en
statsnoop(8) System Manager's Manual statsnoop(8)

statsnoop.bt - Trace stat() syscalls. Uses bpftrace/eBPF.

statsnoop.bt

statsnoop traces the stat() syscall, showing which processes are attempting to stat which files. This can be useful for determining the location of config and log files, or for troubleshooting applications that are failing, specially on startup.

This traces the tracepoints for statfs(), statx(), newstat(), and newlstat(). These aren't the only the stat syscalls: if you are missing activity, you may need to add more variants.

Since this uses BPF, only the root user can use this tool.

CONFIG_BPF and bcc.

# statsnoop.bt

PID Process ID

Thread ID
Process name
File descriptor (if success), or -1 (if failed)
Error number (see the system's errno.h)
Stat path

This traces the stat tracepoints and prints output for each event. As the rate of this is generally expected to be low (< 1000/s), the overhead is also expected to be negligible. If you have an application that is calling a high rate of stat()s, then test and understand overhead before use.

This is from bpftrace.

https://github.com/iovisor/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.

https://github.com/iovisor/bcc

Linux

Unstable - in development.

Brendan Gregg

opensnoop(8), execsnoop(8)

2018-09-08 USER COMMANDS