From owner-freebsd-fs@freebsd.org Sun Aug 7 17:29:16 2016 Return-Path: Delivered-To: freebsd-fs@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 06668BB1697 for ; Sun, 7 Aug 2016 17:29:16 +0000 (UTC) (envelope-from mckusick@chez.mckusick.com) Received: from chez.mckusick.com (chez.mckusick.com [IPv6:2001:5a8:4:7e72:d250:99ff:fe57:4030]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client CN "chez.mckusick.com", Issuer "chez.mckusick.com" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id DD40A1848; Sun, 7 Aug 2016 17:29:15 +0000 (UTC) (envelope-from mckusick@chez.mckusick.com) Received: from chez.mckusick.com (localhost [IPv6:::1]) by chez.mckusick.com (8.15.2/8.15.2) with ESMTP id u77HTEYF087254; Sun, 7 Aug 2016 10:29:14 -0700 (PDT) (envelope-from mckusick@chez.mckusick.com) Message-Id: <201608071729.u77HTEYF087254@chez.mckusick.com> From: Kirk McKusick To: Maxim Sobolev Subject: Re: Optimizing UFS 1/2 for non-rotating / compressed storage cc: FreeBSD Filesystems In-reply-to: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-ID: <87252.1470590954.1@chez.mckusick.com> Date: Sun, 07 Aug 2016 10:29:14 -0700 X-BeenThere: freebsd-fs@freebsd.org X-Mailman-Version: 2.1.22 Precedence: list List-Id: Filesystems List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 07 Aug 2016 17:29:16 -0000 > From: Maxim Sobolev > Date: Sun, 7 Aug 2016 01:09:41 -0700 > Subject: Re: Optimizing UFS 1/2 for non-rotating / compressed storage > To: Kirk McKusick > > Thanks, Kirk, > > So far, we've been set the following, which seems to pessimize compression > levels slightly but greatly reduce size of incremental upgrade using rsync > after we change just few files and re-pack: > > newfs -n -b 65536 -f $((65536 / 2)) -m 0 -L "${FW_LABEL}" "/dev/${MD_UNIT}" > > Unfortunately 64k is the max block size we can get out of it (128k is > rejected) and we run out of inodes if we set fragment size to be 64k as > well. Is there a fundamental limitation on the size of the block? I am > curious to see how 128/32 might work considering that bigger block size is > preferred by the compressor. We'll try to play with other options too, as > you've suggested. > > -Max You can get more inodes by using the -i option to newfs. If you use -i $((65536 / 2)) you should then be able to set the fragment size to the block size. The limit on the block size is set by the kernel. It is not an inherent limitation of the filesystem. If you want to try 128K blocksize, just bump up MAXBSIZE in /sys/sys/param.h to 128k and buildworld. Note that MAXBSIZE cannot exceed MAXPHYS which is currently 128k. I would not recommend trying to push MAXPHYS bigger as that affects a *lot* of the underlying I/O amd VM subsystems. Kirk McKusick