mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-26 01:45:00 +03:00 
			
		
		
		
	OpenZFS 9751 - Allocation throttling misplacing ditto blocks
Relax allocation throttling for ditto blocks. Due to random imbalances in allocation it tends to push block copies to one vdev, that looks slightly better at the moment. Slightly less strict policy allows both improve data security and surprisingly write performance, since we don't need to touch extra metaslabs on each vdev to respect the min distance. Sponsored by: iXsystems, Inc. Authored by: mav <mav@FreeBSD.org> Reviewed by: Matt Ahrens <mahrens@delphix.com> Reviewed by: Pavel Zakharov <pavel.zakharov@delphix.com> Ported-by: Brian Behlendorf <behlendorf1@llnl.gov> OpenZFS-issue: https://illumos.org/issues/9751 FreeBSD-commit: https://github.com/freebsd/freebsd/commit/8253837ac3 Closes #7857
This commit is contained in:
		
							parent
							
								
									e38afd34c3
								
							
						
					
					
						commit
						c197a77c3c
					
				| @ -992,7 +992,7 @@ metaslab_group_fragmentation(metaslab_group_t *mg) | |||||||
|  */ |  */ | ||||||
| static boolean_t | static boolean_t | ||||||
| metaslab_group_allocatable(metaslab_group_t *mg, metaslab_group_t *rotor, | metaslab_group_allocatable(metaslab_group_t *mg, metaslab_group_t *rotor, | ||||||
|     uint64_t psize, int allocator) |     uint64_t psize, int allocator, int d) | ||||||
| { | { | ||||||
| 	spa_t *spa = mg->mg_vd->vdev_spa; | 	spa_t *spa = mg->mg_vd->vdev_spa; | ||||||
| 	metaslab_class_t *mc = mg->mg_class; | 	metaslab_class_t *mc = mg->mg_class; | ||||||
| @ -1033,6 +1033,13 @@ metaslab_group_allocatable(metaslab_group_t *mg, metaslab_group_t *rotor, | |||||||
| 		if (mg->mg_no_free_space) | 		if (mg->mg_no_free_space) | ||||||
| 			return (B_FALSE); | 			return (B_FALSE); | ||||||
| 
 | 
 | ||||||
|  | 		/*
 | ||||||
|  | 		 * Relax allocation throttling for ditto blocks.  Due to | ||||||
|  | 		 * random imbalances in allocation it tends to push copies | ||||||
|  | 		 * to one vdev, that looks a bit better at the moment. | ||||||
|  | 		 */ | ||||||
|  | 		qmax = qmax * (4 + d) / 4; | ||||||
|  | 
 | ||||||
| 		qdepth = refcount_count(&mg->mg_alloc_queue_depth[allocator]); | 		qdepth = refcount_count(&mg->mg_alloc_queue_depth[allocator]); | ||||||
| 
 | 
 | ||||||
| 		/*
 | 		/*
 | ||||||
| @ -1053,7 +1060,7 @@ metaslab_group_allocatable(metaslab_group_t *mg, metaslab_group_t *rotor, | |||||||
| 		 */ | 		 */ | ||||||
| 		for (mgp = mg->mg_next; mgp != rotor; mgp = mgp->mg_next) { | 		for (mgp = mg->mg_next; mgp != rotor; mgp = mgp->mg_next) { | ||||||
| 			qmax = mgp->mg_cur_max_alloc_queue_depth[allocator]; | 			qmax = mgp->mg_cur_max_alloc_queue_depth[allocator]; | ||||||
| 
 | 			qmax = qmax * (4 + d) / 4; | ||||||
| 			qdepth = refcount_count( | 			qdepth = refcount_count( | ||||||
| 			    &mgp->mg_alloc_queue_depth[allocator]); | 			    &mgp->mg_alloc_queue_depth[allocator]); | ||||||
| 
 | 
 | ||||||
| @ -3379,7 +3386,7 @@ top: | |||||||
| 		 */ | 		 */ | ||||||
| 		if (allocatable && !GANG_ALLOCATION(flags) && !try_hard) { | 		if (allocatable && !GANG_ALLOCATION(flags) && !try_hard) { | ||||||
| 			allocatable = metaslab_group_allocatable(mg, rotor, | 			allocatable = metaslab_group_allocatable(mg, rotor, | ||||||
| 			    psize, allocator); | 			    psize, allocator, d); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		if (!allocatable) { | 		if (!allocatable) { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 mav
						mav