summaryrefslogtreecommitdiffstats
path: root/man
diff options
context:
space:
mode:
authorPavel Snajdr <[email protected]>2024-10-04 19:41:17 +0200
committerGitHub <[email protected]>2024-10-04 10:41:17 -0700
commit0d77e738e65d2fdc37c9c345c022f14239ae67cb (patch)
tree9f323470fc410f20566946112f68ffdbc83a1c82 /man
parent3d0175d10e1114aaf94255c09f6d9ad45a333255 (diff)
Defer resilver only when progress is above a threshold
Restart a resilver from scratch, if the current one in progress is below a new tunable, zfs_resilver_defer_percent (defaulting to 10%). The original rationale for deferring additional resilvers, when there is already one in progress, was to help achieving data redundancy sooner for the data that gets scanned at the end of the resilver. But in case the admin wants to attach multiple disks to a single vdev, it wasn't immediately obvious the admin is supposed to run `zpool resilver` afterwards to reset the deferred resilvers and start a new one from scratch. Reviewed-by: Brian Behlendorf <[email protected]> Signed-off-by: Pavel Snajdr <[email protected]> Closes #15810
Diffstat (limited to 'man')
-rw-r--r--man/man4/zfs.47
1 files changed, 7 insertions, 0 deletions
diff --git a/man/man4/zfs.4 b/man/man4/zfs.4
index cf6720317..e19573d5e 100644
--- a/man/man4/zfs.4
+++ b/man/man4/zfs.4
@@ -2012,6 +2012,13 @@ Ignore the
feature, causing an operation that would start a resilver to
immediately restart the one in progress.
.
+.It Sy zfs_resilver_defer_percent Ns = Ns Sy 10 Ns % Pq uint
+If the ongoing resilver progress is below this threshold, a new resilver will
+restart from scratch instead of being deferred after the current one finishes,
+even if the
+.Sy resilver_defer
+feature is enabled.
+.
.It Sy zfs_resilver_min_time_ms Ns = Ns Sy 3000 Ns ms Po 3 s Pc Pq uint
Resilvers are processed by the sync thread.
While resilvering, it will spend at least this much time