Files
mirror_zfs/include/sys
Alan Somers a0e01997ec Parallelize vdev_load
metaslab_init is the slowest part of importing a mature pool, and it
must be repeated hundreds of times for each top-level vdev.  But its
speed is dominated by a few serialized disk accesses.  That can lead to
import times of > 1 hour for pools with many top-level vdevs on spinny
disks.

Speed up the import by using a taskqueue to parallelize vdev_load across
all top-level vdevs.

This also requires adding mutex protection to
metaslab_class_t.mc_historgram.  The mc_histogram fields were
unprotected when that code was first written in "Illumos 4976-4984 -
metaslab improvements" (OpenZFS
f3a7f6610f).  The lock wasn't added until
3dfb57a35e, though it's unclear exactly
which fields it's supposed to protect.  In any case, it wasn't until
vdev_load was parallelized that any code attempted concurrent access to
those fields.

Sponsored by: Axcient
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Alan Somers <asomers@gmail.com>
Closes #11470
2021-01-26 19:35:59 -08:00
..
2021-01-20 21:27:30 -08:00
2020-09-04 10:34:28 -07:00
2020-09-22 16:03:11 -07:00
2020-10-30 15:26:10 -07:00
2020-12-12 16:00:00 -08:00
2020-12-10 14:09:23 -08:00
2019-10-09 10:36:03 -07:00
2019-07-26 10:54:14 -07:00
2019-07-26 10:54:14 -07:00
2019-06-19 09:48:12 -07:00
2020-06-09 21:24:09 -07:00
2019-06-19 09:48:12 -07:00
2020-01-10 10:16:58 -08:00
2019-06-19 09:48:12 -07:00
2020-07-29 16:35:33 -07:00
2021-01-21 15:12:54 -08:00
2020-07-29 16:35:33 -07:00
2019-06-24 16:44:01 -07:00
2019-07-26 10:54:14 -07:00
2020-07-29 16:35:33 -07:00
2020-11-13 13:51:51 -08:00
2020-09-04 10:29:39 -07:00
2013-11-04 11:17:48 -08:00
2019-08-30 09:53:15 -07:00
2017-10-11 16:54:48 -04:00
2020-11-13 13:51:51 -08:00
2018-05-29 16:00:33 -07:00
2019-06-19 09:48:12 -07:00
2019-09-12 13:33:44 -07:00
2020-07-29 16:35:33 -07:00
2020-07-29 16:35:33 -07:00
2021-01-20 21:27:30 -08:00
2021-01-21 15:12:54 -08:00
2019-07-16 10:11:49 -07:00
2021-01-21 15:12:54 -08:00
2019-08-30 09:53:15 -07:00
2020-11-13 13:51:51 -08:00
2020-10-02 17:44:10 -07:00
2017-07-13 13:54:00 -04:00
2021-01-20 21:27:30 -08:00
2013-11-04 10:55:25 -08:00
2020-11-13 13:51:51 -08:00
2021-01-26 19:35:59 -08:00
2019-03-29 09:13:20 -07:00
2020-11-13 13:51:51 -08:00
2020-06-09 10:15:08 -07:00
2021-01-21 15:12:54 -08:00
2019-06-12 13:13:09 -07:00
2018-02-08 15:28:18 -08:00
2018-02-08 15:28:18 -08:00
2020-11-02 11:51:12 -08:00
2018-05-29 16:00:33 -07:00
2020-10-13 21:25:48 -07:00
2021-01-20 21:27:30 -08:00
2018-09-06 21:44:52 -07:00
2021-01-20 21:27:30 -08:00
2020-11-10 12:42:47 -08:00
2019-06-10 11:48:42 -07:00
2017-03-29 12:24:51 -07:00
2020-08-20 10:30:06 -07:00
2020-08-20 10:30:06 -07:00
2020-07-03 11:05:50 -07:00
2020-11-13 13:51:51 -08:00
2020-07-29 09:43:33 -07:00