Answers:
DTrace能够报告FreeBSD中的vfs信息(以及许多其他探针)。默认情况下,DTrace在10内核中处于启用状态,因此您所需要做的就是加载模块,然后运行dtrace脚本。
加载DTrace模块
kldload dtraceall
从FreeBSD论坛获取vfssnoop.d脚本。在整个主题是磁盘监控的宝库。
运行:
./vfssnoop.d
观察输出中所访问的内容:
# ./vfssnoop.d
cc1: warning: is shorter than expected
TIMESTAMP UID PID PROCESS CALL SIZE PATH/FILE
1555479476691083 0 1225 nfsd vop_getattr - /share/netboot
1555479478601010 0 1225 nfsd vop_inactive - /share/netboot
1555479482457241 0 1225 nfsd vop_getattr - /share/wpad.dat
1555480557262388 0 1432 cron vop_getattr - /var/cron/tabs
1555480557302178 0 1432 cron vop_inactive - /var/cron/tabs
1555480557336414 0 1432 cron vop_inactive - /etc
1555480557346224 0 1432 cron vop_getattr - /etc/crontab
top
查找正在消耗磁盘I / O的proc怎么样?:top -m io -o total
:freebsd.org/cgi/...