Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 13 Sep 2014 17:24:57 +0000 (UTC)
From:      Xin LI <delphij@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r271532 - head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs
Message-ID:  <201409131724.s8DHOvJR037169@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: delphij
Date: Sat Sep 13 17:24:56 2014
New Revision: 271532
URL: http://svnweb.freebsd.org/changeset/base/271532

Log:
  MFV r271515:
  
  Add a new tunable/sysctl, vfs.zfs.free_max_blocks, which can be used to
  limit how many blocks can be free'ed before a new transaction group is
  created.  The default is no limit (infinite), but we should probably have
  a lower default, e.g. 100,000.
  
  With this limit, we can guard against the case where ZFS could run out of
  memory when destroying large numbers of blocks in a single transaction
  group, as the entire DDT needs to be brought into memory.
  
  Illumos issue:
      5138 add tunable for maximum number of blocks freed in one txg
  
  MFC after:	2 weeks

Modified:
  head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_scan.c
Directory Properties:
  head/sys/cddl/contrib/opensolaris/   (props changed)

Modified: head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_scan.c
==============================================================================
--- head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_scan.c	Sat Sep 13 17:14:01 2014	(r271531)
+++ head/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/dsl_scan.c	Sat Sep 13 17:24:56 2014	(r271532)
@@ -90,6 +90,11 @@ SYSCTL_INT(_vfs_zfs, OID_AUTO, no_scrub_
     &zfs_no_scrub_prefetch, 0, "Disable scrub prefetching");
 
 enum ddt_class zfs_scrub_ddt_class_max = DDT_CLASS_DUPLICATE;
+/* max number of blocks to free in a single TXG */
+uint64_t zfs_free_max_blocks = UINT64_MAX;
+SYSCTL_UQUAD(_vfs_zfs, OID_AUTO, free_max_blocks, CTLFLAG_RWTUN,
+    &zfs_free_max_blocks, 0, "Maximum number of blocks to free in one TXG");
+
 
 #define	DSL_SCAN_IS_SCRUB_RESILVER(scn) \
 	((scn)->scn_phys.scn_func == POOL_SCAN_SCRUB || \
@@ -1341,6 +1346,9 @@ dsl_scan_free_should_pause(dsl_scan_t *s
 	if (zfs_recover)
 		return (B_FALSE);
 
+	if (scn->scn_visited_this_txg >= zfs_free_max_blocks)
+		return (B_TRUE);
+
 	elapsed_nanosecs = gethrtime() - scn->scn_sync_start_time;
 	return (elapsed_nanosecs / NANOSEC > zfs_txg_timeout ||
 	    (NSEC2MSEC(elapsed_nanosecs) > zfs_free_min_time_ms &&



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201409131724.s8DHOvJR037169>