Page MenuHomeFreeBSD

zfsd: fault disks that generate too many I/O delay events
ClosedPublic

Authored by asomers on Nov 28 2023, 11:07 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 4 2024, 9:43 AM
Unknown Object (File)
Dec 1 2024, 11:37 PM
Unknown Object (File)
Nov 15 2024, 1:27 PM
Unknown Object (File)
Oct 2 2024, 11:34 AM
Unknown Object (File)
Sep 25 2024, 9:21 AM
Unknown Object (File)
Sep 24 2024, 4:05 PM
Unknown Object (File)
Sep 22 2024, 2:23 AM
Unknown Object (File)
Sep 19 2024, 4:26 PM

Details

Summary

If ZFS reports that a disk had at least 8 I/O operations over 60s that
were each delayed by at least 30s (implying a queue depth > 5 or I/O
aggregation, obviously), fault that disk. Disks that respond this
slowly can degrade the entire system's performance.

MFC after: 2 weeks
Sponsored by: Axcient

Test Plan

unit and integration tests added. Change has been run in production for 4 months, where it faults about 0.2% of HDDs annually.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

delphij added inline comments.
cddl/usr.sbin/zfsd/case_file.h
239

Should these converted to const int's instead of being enum?

This revision is now accepted and ready to land.Nov 29 2023, 6:47 AM
asomers added inline comments.
cddl/usr.sbin/zfsd/case_file.h
239

Good question. They certainly could be. I suspect that it was @gibbs who initially created them as enums. BTW, in a future commit I'm planning to make these customizable via vdev properties, as suggested by @allanjude . I'll convert them to const int at that time.

I'd have liked to see these configurable thresholds for people that want to more or less aggressively fault things.
But as is, it's fine, and it's a nice to have not something absolutely required.

In D42825#976834, @imp wrote:

I'd have liked to see these configurable thresholds for people that want to more or less aggressively fault things.
But as is, it's fine, and it's a nice to have not something absolutely required.

Yes, definitely. I'm going to make them configurable next, using Allan Jude's suggested method.

FYI: One of the things I have planned for after the first of the year is to start publishing from the CAM io scheduler latencies that exceed some threshold, either static (> 30s) or dynamic (> 5MAD from median). I'd planned on using this stream to accumulate in real time the notion of an unresponsive disk and use that to inform our system's continued use of the disk. Interesting to see parallel work.