Matthew Ahrens
d9b4bf0665
fat zap should prefetch when iterating
...
When iterating over a ZAP object, we're almost always certain to iterate
over the entire object. If there are multiple leaf blocks, we can
realize a performance win by issuing reads for all the leaf blocks in
parallel when the iteration begins.
For example, if we have 10,000 snapshots, "zfs destroy -nv
pool/fs@1%9999" can take 30 minutes when the cache is cold. This change
provides a >3x performance improvement, by issuing the reads for all ~64
blocks of each ZAP object in parallel.
Reviewed-by: Andreas Dilger <andreas.dilger@whamcloud.com>
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Matthew Ahrens <mahrens@delphix.com>
External-issue: DLPX-58347
Closes #8862
2019-06-12 13:13:09 -07:00
..
2019-06-11 09:02:31 -07:00
2018-10-19 12:08:03 -07:00
2019-06-12 13:06:55 -07:00
2017-11-04 13:25:13 -07:00
2015-01-16 14:41:26 -08:00
2019-03-06 09:50:55 -08:00
2017-08-14 10:36:48 -07:00
2019-06-03 20:54:43 -07:00
2018-06-06 09:35:59 -07:00
2019-02-12 10:41:15 -08:00
2018-10-01 10:42:05 -07:00
2019-05-07 15:18:44 -07:00
2019-06-12 13:13:09 -07:00
2019-01-17 15:25:00 -08:00
2018-05-01 11:24:20 -07:00
2019-05-07 15:18:44 -07:00
2019-02-19 18:41:18 -08:00
2019-06-10 09:45:08 -07:00
2019-05-07 15:18:44 -07:00
2018-08-15 09:53:44 -07:00
2018-10-01 10:42:05 -07:00
2019-05-23 13:46:33 -07:00
2019-06-12 13:13:09 -07:00
2019-06-06 13:47:33 -07:00
2019-05-19 17:30:33 -07:00
2019-03-13 11:00:43 -07:00
2019-03-14 16:48:30 -07:00
2019-03-21 10:36:58 -07:00
2018-04-14 12:16:17 -07:00
2018-05-29 16:00:33 -07:00
2019-01-08 10:17:46 -08:00
2019-04-12 11:30:59 -07:00
2019-02-12 10:41:15 -08:00
2018-05-29 16:00:33 -07:00
2019-06-03 09:40:48 -07:00
2018-06-26 10:07:42 -07:00
2019-02-15 12:41:38 -08:00
2016-11-29 14:34:27 -08:00
2018-07-30 11:30:03 -07:00
2018-05-29 16:00:33 -07:00
2017-10-11 16:54:48 -04:00
2019-05-02 16:46:04 -07:00
2015-01-16 14:41:26 -08:00
2019-03-29 09:13:20 -07:00
2019-06-06 19:10:43 -07:00
2019-03-21 12:47:57 -07:00
2018-05-29 16:00:33 -07:00
2018-05-29 16:00:33 -07:00
2018-03-07 15:40:42 -08:00
2019-04-16 12:38:36 -07:00
2019-04-16 12:38:36 -07:00
2019-04-16 12:38:36 -07:00
2019-04-16 12:38:36 -07:00
2019-04-04 18:57:06 -07:00
2018-10-09 10:05:48 -07:00
2018-10-01 10:42:05 -07:00
2018-10-01 10:42:05 -07:00
2018-03-15 10:53:58 -07:00
2016-11-29 14:34:27 -08:00
2010-08-31 13:41:58 -07:00
2019-02-12 10:38:11 -08:00
2019-05-29 16:18:14 -07:00
2018-05-29 16:00:33 -07:00
2018-10-08 21:57:02 -07:00
2019-05-23 19:17:00 -07:00
2019-04-04 18:57:06 -07:00
2019-05-09 10:08:05 -07:00
2019-04-04 18:57:06 -07:00
2018-04-14 12:16:17 -07:00
2018-06-06 09:35:59 -07:00
2018-06-06 09:35:59 -07:00
2018-04-14 12:16:17 -07:00
2019-04-04 09:44:46 -07:00
2019-03-21 12:47:57 -07:00
2016-08-31 14:35:34 -07:00
2018-05-29 16:00:33 -07:00
2019-05-04 16:39:10 -07:00
2019-04-25 10:17:27 -07:00
2018-05-29 16:00:33 -07:00
2019-02-12 10:38:11 -08:00
2019-05-24 12:17:52 -07:00
2019-03-29 09:13:20 -07:00
2019-03-29 09:13:20 -07:00
2019-04-14 11:03:06 -07:00
2019-01-07 10:37:26 -08:00
2019-03-29 09:13:20 -07:00
2019-05-08 10:18:40 -07:00
2017-01-22 13:25:40 -08:00
2016-11-29 14:34:33 -08:00
2019-05-08 10:18:40 -07:00
2019-05-08 10:18:40 -07:00
2016-12-12 10:46:26 -08:00
2017-01-22 13:25:40 -08:00
2016-11-29 14:34:33 -08:00
2016-11-29 14:34:33 -08:00
2019-05-08 10:18:40 -07:00
2019-06-12 13:03:33 -07:00
2019-03-29 09:13:20 -07:00
2019-04-04 18:57:06 -07:00
2019-01-07 10:37:26 -08:00
2019-03-29 09:13:20 -07:00
2019-06-06 19:10:43 -07:00
2019-01-18 09:58:46 -08:00
2019-06-12 13:13:09 -07:00
2019-06-12 13:13:09 -07:00
2019-03-13 11:00:43 -07:00
2018-02-08 15:29:24 -08:00
2018-07-12 10:49:27 -07:00
2018-06-26 10:07:42 -07:00
2018-07-10 21:29:23 -07:00
2019-04-16 10:01:51 -07:00
2018-05-29 16:00:33 -07:00
2018-05-29 16:00:33 -07:00
2019-05-24 16:43:23 -07:00
2019-04-04 18:57:06 -07:00
2019-02-12 10:41:15 -08:00
2018-11-08 16:47:24 -08:00
2018-05-29 16:00:33 -07:00
2019-05-29 16:18:14 -07:00
2019-06-10 11:48:42 -07:00
2018-05-29 16:00:33 -07:00
2018-03-04 17:34:51 -08:00
2019-04-25 10:17:27 -07:00
2018-10-11 10:19:33 -07:00
2018-02-13 14:54:54 -08:00
2019-04-04 19:00:55 -07:00
2019-05-08 16:43:55 -07:00
2019-05-25 14:29:10 -07:00
2019-06-06 12:59:39 -07:00
2019-06-10 11:48:42 -07:00
2017-11-04 13:25:13 -07:00
2018-08-29 11:33:33 -07:00
2019-04-10 15:39:40 -07:00
2019-03-15 14:14:31 -07:00
2019-06-11 09:02:31 -07:00
2018-02-09 10:08:05 -08:00
2018-05-02 15:01:24 -07:00
2016-12-12 10:46:26 -08:00
2019-05-08 10:04:04 -07:00
2019-05-08 10:04:04 -07:00
2018-09-24 17:11:25 -07:00
2018-08-02 14:03:56 -07:00
2018-05-29 16:00:33 -07:00
2019-04-04 09:44:46 -07:00
2019-06-10 11:48:42 -07:00