Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ZFS traverse_visitbp optimization to limit prefetch.
Traversal code, traverse_visitbp() does visit blocks recursively. Indirect (Non L0) Block of size 128k could contain, 1024 block pointers of 128 bytes. In case of full traverse OR incremental traverse, where all blocks were modified, it could traverse large number of blocks pointed by indirect. Traversal code does issue prefetch of blocks traversed below indirect. This could result into large number of async reads queued on vdev queue. So, account for prefetch issued for blocks pointed by indirect and limit max prefetch in one go. Module Param: zfs_traverse_indirect_prefetch_limit: Limit of prefetch while traversing an indirect block Local counters: prefetched: Local counter to account for number prefetch done. prefetchidx: Index for which next prefetch to be issued. prefetchtriggeridx: Index at which next prefetch to be triggered. Keeps prefetchtriggeridx somewhere in the middle of blocks prefetched, so that prefetching blocks gets a enough time window before their demand read is issued. Signed-off-by: Jitendra Patidar <jitendra.patidar@nutanix.com> Closes openzfs#11802
- Loading branch information