(我的系统是Debian 11 Bullseye + GNOME 3.38.6)
我有一个 Seagate 2TB 仅用于存储目的,由于它的噪音很大,我将其置于睡眠状态,除非我使用以下命令访问存储:
sudo hdparm -Y /dev/sda
当执行上述操作时,硬盘驱动器进入睡眠状态,但几分钟后,有东西唤醒了硬盘驱动器,我不知道是什么。
我检查了日志,显然每 10 分钟硬盘再次唤醒之前就会发生以下情况:
Jun 09 20:36:59 user0 kernel: ata2: SATA link up 6.0 Gbps (SStatus 133 SControl 300)
Jun 09 20:36:59 user0 kernel: ata2.00: ACPI cmd ef/10:06:00:00:00:00 (SET FEATURES) succeeded
Jun 09 20:36:59 user0 kernel: ata2.00: ACPI cmd f5/00:00:00:00:00:00 (SECURITY FREEZE LOCK) filtered out
Jun 09 20:36:59 user0 kernel: ata2.00: ACPI cmd b1/c1:00:00:00:00:00 (DEVICE CONFIGURATION OVERLAY) filtered out
Jun 09 20:37:02 user0 kernel: ata2.00: ACPI cmd ef/10:06:00:00:00:00 (SET FEATURES) succeeded
Jun 09 20:37:02 user0 kernel: ata2.00: ACPI cmd f5/00:00:00:00:00:00 (SECURITY FREEZE LOCK) filtered out
Jun 09 20:37:02 user0 kernel: ata2.00: ACPI cmd b1/c1:00:00:00:00:00 (DEVICE CONFIGURATION OVERLAY) filtered out
Jun 09 20:37:02 user0 kernel: ata2.00: configured for UDMA/133
造成这种情况的原因/如何防止这种情况?
更新。上述消息仅在 HDD 处于休眠状态时才会出现。否则它们不会在日志中重复出现。
答案1
以下内容可以帮助您了解导致此问题的原因,但不能帮助您解决问题。
您将需要一个用 编译的内核CONFIG_BLK_DEV_IO_TRACE=y
(您可以使用命令检查这一点$ zcat /proc/config.gz |grep BLK_DEV_IO_TRACE
,但前提是内核是用 编译的CONFIG_IKCONFIG_PROC=y
)。
现在您已经拥有了,您可以使用btrace
/blktrace
(debian 软件包是块跟踪) 作为根,例如:
$ sudo btrace /dev/sdc
或等效的:sudo blktrace -d /dev/sdc -o - | blkparse -i -
这将为您提供如下输出,但仅当访问 /dev/sdc (自己使用 sda)时发生:
8,32 4 1 0.000000000 35200 Q FWS [sync]
8,32 4 2 0.000005329 35200 G FWS [sync]
8,32 4 3 0.000024868 166 D FN [kworker/4:1H]
8,32 0 1 0.005341892 35201 D R 36 [sdparm]
8,32 0 2 0.005360604 12 C R [0]
8,32 0 3 0.005483027 35201 D N 0 [sdparm]
8,32 2 1 0.008090821 13354 D R 32 [(null)]
8,32 2 2 0.008109065 24 C R [0]
8,32 2 3 0.008274033 13354 D R 64 [(null)]
8,32 2 4 0.008290535 24 C R [0]
8,32 2 5 0.008435087 13354 D R 64 [(null)]
8,32 2 6 0.008451221 24 C R [0]
8,32 2 7 0.008649311 13354 D R 8256 [(null)]
8,32 2 8 0.008665588 24 C R [65415]
8,32 2 9 0.008839399 13354 D R 8 [(null)]
8,32 2 10 0.008856004 24 C R [0]
8,32 2 11 0.008905781 13354 D R 512 [(null)]
8,32 2 12 0.008913061 24 C R [0]
8,32 2 13 0.008957477 13354 D R 512 [(null)]
8,32 2 14 0.008963625 24 C R [0]
8,32 2 15 0.017343228 35206 Q RA 35156656000 + 8 [udevd]
8,32 2 16 0.017344264 35206 G RA 35156656000 + 8 [udevd]
8,32 2 17 0.017344513 35206 P N [udevd]
8,32 2 18 0.017344733 35206 U N [udevd] 1
8,32 2 19 0.017344993 35206 I RA 35156656000 + 8 [udevd]
8,32 2 20 0.017346335 35206 D RA 35156656000 + 8 [udevd]
8,32 2 21 0.017613109 35206 Q RA 35156655864 + 8 [udevd]
8,32 2 22 0.017613575 35206 G RA 35156655864 + 8 [udevd]
8,32 2 23 0.017613672 35206 P N [udevd]
8,32 2 24 0.017613775 35206 U N [udevd] 1
8,32 2 25 0.017613935 35206 I RA 35156655864 + 8 [udevd]
8,32 2 26 0.017614656 35206 D RA 35156655864 + 8 [udevd]
8,32 2 27 0.017728317 35206 Q RA 35156656064 + 8 [udevd]
8,32 2 28 0.017728616 35206 G RA 35156656064 + 8 [udevd]
8,32 2 29 0.017728680 35206 P N [udevd]
8,32 2 30 0.017728750 35206 U N [udevd] 1
您可以看到一些使用/dev/sdc的进程名称,例如sync、sdparm、udevd和kernel kworker。