为什么 `ioerr_cnt` 不断上升,但日志中没有显示任何消息?
我正在努力弄清楚什么过程是这样做的。
sudo lsof +D /dev/
似乎没有显示当前打开的 SCSI 设备的任何进程,但在发生错误时我也没有看到任何相关的 open() 调用 (cd /dev && sudo fatrace -c
)...[答案:] udisks 每十分钟轮询一次驱动器,例如 SMART 数据。
$ ps -ax|grep udisksd 810 ? Ssl 0:13 /usr/libexec/udisks2/udisksd $ sudo strace -t -f -p 810 [pid 810] 14:11:09 clone(strace: Process 26543 attached child_stack=0x7f8fc551ddf0, flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SYSVSEM|CLONE_SETTLS|CLONE_PARENT_SETTID|CLONE_CHILD_CLEARTID, parent_tidptr=0x7f8fc551e9d0, tls=0x7f8fc551e700, child_tidptr=0x7f8fc551e9d0) = 26543 [pid 26543] 14:11:09 set_robust_list(0x7f8fc551e9e0, 24 <unfinished ...> [pid 810] 14:11:09 poll([{fd=4, events=POLLIN}, {fd=8, events=0}, {fd=9, events=0}, {fd=11, events=POLLIN}, {fd=13, events=POLLIN}], 5, 599968 <unfinished ...> [pid 26543] 14:11:09 <... set_robust_list resumed> ) = 0 [pid 26543] 14:11:09 prctl(PR_SET_NAME, "pool") = 0 [pid 26543] 14:11:09 openat(AT_FDCWD, "/dev/sda", O_RDONLY|O_NONBLOCK) = 14 [pid 26543] 14:11:09 ioctl(14, SG_IO, {guard='Q', protocol=BSG_PROTOCOL_SCSI, subprotocol=BSG_SUB_PROTOCOL_SCSI_CMD, ...
我不知道为什么
fatrace
似乎没有显示该设备被 udisks 打开。它设法显示其他设备打开(例如当我运行 lsof 时,或者当我启动 firefox 时它打开了 /dev/dri/card0 )。
^ 有人知道吗?
答案1
好像fatrace
不显示任何设备打开。您可以使用它来查看进程打开情况目录下/dev
,喜欢/dev/dri
,但不是设备节点喜欢/dev/dri/card0
。