Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multi-thread 'zpool import' for blkid #4794

Closed
wants to merge 1 commit into from

Conversation

behlendorf
Copy link
Contributor

Commit 519129f adding support to multi-thread 'zpool import' for
the case where block devices are scanned for under /dev/. This
commit generalizes that logic and applies it to the case where
device names are aquired from libblkid.

The zpool_find_import_scan() and zpool_find_import_blkid()
functions create an AVL tree with each device name. Each entry
in this tree is then dispatched to a taskq where the function
zpool_open_func() validates the device by opening it and reading
the label. This may result in additional entries being added
to the tree and those device paths being verified.

This is largely how the upstream OpenZFS code behaves but due to
significant differences the non-Linux code has been dropped for
readability. Additionally, this code makes use of taskqs and
kmutexs which are normally not available to the command line tools.
Special care has been taken to allow their use in the import
functions.

Signed-off-by: Brian Behlendorf [email protected]

@behlendorf behlendorf added the Type: Performance Performance improvement or performance problem label Jun 24, 2016
@behlendorf behlendorf added this to the 0.7.0 milestone Jun 24, 2016
@behlendorf
Copy link
Contributor Author

On a system with a large number of drives (~160) which are reachable from multiple device paths this significantly speeds up the blkid based import. In my testing zpool import times dropped from ~200 seconds to ~5 seconds.

@behlendorf behlendorf force-pushed the zpool-import-speedup branch 2 times, most recently from 863fd28 to 1f54f7a Compare June 30, 2016 23:44
@behlendorf
Copy link
Contributor Author

@ofaaland could you review this.

@behlendorf behlendorf force-pushed the zpool-import-speedup branch 2 times, most recently from 7ecc7da to f8a9f1a Compare July 14, 2016 23:30
behlendorf added a commit to behlendorf/zfs that referenced this pull request Jul 14, 2016
Commit 519129f added support to multi-thread 'zpool import' for
the case where block devices are scanned for under /dev/.  This
commit generalizes that logic and applies it to the case where
device names are acquired from libblkid.

The zpool_find_import_scan() and zpool_find_import_blkid()
functions create an AVL tree containing each device name.  Each
entry in this tree is dispatched to a taskq where the function
zpool_open_func() validates the device by opening it and reading
the label.  This may result in additional entries being added
to the tree and those device paths being verified.

This is largely how the upstream OpenZFS code behaves but due to
significant differences the non-Linux code has been dropped for
readability.  Additionally, this code makes use of taskqs and
kmutexs which are normally not available to the command line tools.
Special care has been taken to allow their use in the import
functions.

Signed-off-by: Brian Behlendorf <[email protected]>
Signed-off-by: Olaf Faaland <[email protected]>
Closes openzfs#4794
@behlendorf behlendorf force-pushed the zpool-import-speedup branch from f8a9f1a to 6b29677 Compare July 18, 2016 22:00
behlendorf added a commit to behlendorf/zfs that referenced this pull request Jul 18, 2016
Commit 519129f added support to multi-thread 'zpool import' for
the case where block devices are scanned for under /dev/.  This
commit generalizes that logic and applies it to the case where
device names are acquired from libblkid.

The zpool_find_import_scan() and zpool_find_import_blkid()
functions create an AVL tree containing each device name.  Each
entry in this tree is dispatched to a taskq where the function
zpool_open_func() validates the device by opening it and reading
the label.  This may result in additional entries being added
to the tree and those device paths being verified.

This is largely how the upstream OpenZFS code behaves but due to
significant differences the non-Linux code has been dropped for
readability.  Additionally, this code makes use of taskqs and
kmutexs which are normally not available to the command line tools.
Special care has been taken to allow their use in the import
functions.

Signed-off-by: Brian Behlendorf <[email protected]>
Signed-off-by: Olaf Faaland <[email protected]>
Closes openzfs#4794
Commit 519129f added support to multi-thread 'zpool import' for
the case where block devices are scanned for under /dev/.  This
commit generalizes that logic and applies it to the case where
device names are acquired from libblkid.

The zpool_find_import_scan() and zpool_find_import_blkid()
functions create an AVL tree containing each device name.  Each
entry in this tree is dispatched to a taskq where the function
zpool_open_func() validates the device by opening it and reading
the label.  This may result in additional entries being added
to the tree and those device paths being verified.

This is largely how the upstream OpenZFS code behaves but due to
significant differences the non-Linux code has been dropped for
readability.  Additionally, this code makes use of taskqs and
kmutexs which are normally not available to the command line tools.
Special care has been taken to allow their use in the import
functions.

Signed-off-by: Brian Behlendorf <[email protected]>
Signed-off-by: Olaf Faaland <[email protected]>
Closes openzfs#4794
@behlendorf behlendorf force-pushed the zpool-import-speedup branch from 6b29677 to c528b9f Compare July 26, 2016 16:52
@ofaaland
Copy link
Contributor

Looks good to me.

@behlendorf behlendorf deleted the zpool-import-speedup branch April 19, 2021 19:35
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Type: Performance Performance improvement or performance problem
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants