mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-22 10:37:35 +03:00
Change target size of metaslabs from 256GB to 16GB
= Old behavior For vdev sizes 100GB to 50TB we keep ~200 metaslabs per vdev and the metaslab size grows from 512MB to 256GB. For vdev's bigger than that we start increasing the number of metaslabs until we hit the 128K limit. = New Behavior For vdev sizes 100GB to 3TB we keep ~200 metaslabs per vdev and the metaslab size grows from 512MB to 16GB. For vdev's bigger than that we start increasing the number of metaslabs until we hit the 128K limit. = Reasoning The old behavior makes metaslabs grow in size when the vdev range is between 3TB (ms_size 16GB) and 32PB (ms_size 256GB). Even though keeping the number of metaslabs is good in terms of potential number of I/Os per TXG, these bigger metaslabs take longer to be loaded and after they are loaded they can take up a lot of memory because of their range trees. This change tries to put a boundary in memory and loading time for the specific range of vdev sizes. Reviewed-by: Matt Ahrens <mahrens@delphix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Don Brady <don.brady@delphix.com> Signed-off-by: Serapheim Dimitropoulos <serapheim@delphix.com> Closes #8324
This commit is contained in:
committed by
Brian Behlendorf
parent
df72b8bebe
commit
c853f382db
+2
-2
@@ -48,7 +48,7 @@ function custom_cleanup
|
||||
{
|
||||
set_vdev_validate_skip 0
|
||||
cleanup
|
||||
log_must set_tunable64 vdev_min_ms_count 16
|
||||
log_must set_tunable64 zfs_vdev_min_ms_count 16
|
||||
}
|
||||
|
||||
log_onexit custom_cleanup
|
||||
@@ -208,7 +208,7 @@ increase_device_sizes $(( FILE_SIZE * 4 ))
|
||||
|
||||
# Increase the number of metaslabs for small pools temporarily to
|
||||
# reduce the chance of reusing a metaslab that holds old MOS metadata.
|
||||
log_must set_tunable64 vdev_min_ms_count 150
|
||||
log_must set_tunable64 zfs_vdev_min_ms_count 150
|
||||
|
||||
# Part of the rewind test is to see how it reacts to path changes
|
||||
typeset pathstochange="$VDEV0 $VDEV1 $VDEV2 $VDEV3"
|
||||
|
||||
Reference in New Issue
Block a user