Page MenuHomeFreeBSD

ZFS sorted scans
ClosedPublic

Authored by sef on May 24 2018, 8:00 PM.
Tags
Referenced Files
F133338721: D15562.id43455.diff
Sat, Oct 25, 1:06 AM
Unknown Object (File)
Fri, Oct 24, 6:53 PM
Unknown Object (File)
Fri, Oct 24, 11:14 AM
Unknown Object (File)
Fri, Oct 24, 11:14 AM
Unknown Object (File)
Fri, Oct 24, 11:14 AM
Unknown Object (File)
Fri, Oct 24, 1:47 AM
Unknown Object (File)
Thu, Oct 16, 12:43 AM
Unknown Object (File)
Tue, Oct 14, 5:25 AM

Details

Reviewers
mav
Group Reviewers
ZFS
Commits
rS334844: This originated from ZFS On Linux, as
Summary

This originated from ZFS On Linux, as https://github.com/zfsonlinux/zfs/commit/d4a72f23863382bdf6d0ae33196f5b5decbc48fd

During scans (scrubs or resilvers), it sorts the blocks in each transaction group by block offset; the result can be a significant improvement. (On my test system just now, which I put some effort to introduce fragmentation into the pool since I set it up yesterday, a scrub went from 1h2m to 33.5m with the changes.) I've seen similar rations on production systems.

FreeNAS has had these changes since Oct 2017.

Test Plan

Scrub & rebuild pools. Note times for performance analysis.

The pools are compatible with systems without the changes, so bouncing back and forth between two versions is possible, and I've used that for correctness-checking.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

Just a quick question, is this the same change that was recently presented at OpenZFS summit (http://open-zfs.org/w/images/a/a0/Saso_-_resilver_update.pdf)?
Or an alternative to it?

In D15562#328648, @avg wrote:

Just a quick question, is this the same change that was recently presented at OpenZFS summit (http://open-zfs.org/w/images/a/a0/Saso_-_resilver_update.pdf)?
Or an alternative to it?

Same one, I believe. (Note that I started with the ZoL patches the middle of last year.)

A late sequential-scan-related patch was mentioned when I created the PR for OpenZFS, it's at https://github.com/zfsonlinux/zfs/commit/a8b2e30685c9214c

I don't think it is a very good idea to merge two pretty much independent ZoL commits into one FreeBSD commit. It could have sense if the first one would be significantly broken and second fixed the issue, but priority upgrade implemented in second commit is only a performance optimization, mostly unrelated to scrub even, in which case having it separate would make commit history cleaner for later comparison.

In D15562#329076, @mav wrote:

I don't think it is a very good idea to merge two pretty much independent ZoL commits into one FreeBSD commit. It could have sense if the first one would be significantly broken and second fixed the issue, but priority upgrade implemented in second commit is only a performance optimization, mostly unrelated to scrub even, in which case having it separate would make commit history cleaner for later comparison.

I thought about that, but I figured since I'm already getting this change in, and I added it to my PR for OpenZFS, I may as well do it here as well.

I can remove it easily enough.

Alexander pointed out that what I'd undone a change (range_tree_create()) because I'd ported from our 11-base system. Fixed that, and scrubbed a system a few times.

This revision is now accepted and ready to land.Jun 8 2018, 7:58 PM
This revision was automatically updated to reflect the committed changes.