From owner-freebsd-fs@FreeBSD.ORG Sat Jun 20 05:21:10 2015 Return-Path: Delivered-To: freebsd-fs@hub.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [8.8.178.115]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 47D3F305 for ; Sat, 20 Jun 2015 05:21:10 +0000 (UTC) (envelope-from mcdouga9@egr.msu.edu) Received: from mail.egr.msu.edu (boomhauer.egr.msu.edu [35.9.37.167]) by mx1.freebsd.org (Postfix) with ESMTP id 20FE2EF6 for ; Sat, 20 Jun 2015 05:21:09 +0000 (UTC) (envelope-from mcdouga9@egr.msu.edu) Received: from boomhauer (localhost [127.0.0.1]) by mail.egr.msu.edu (Postfix) with ESMTP id 24E2729661 for ; Sat, 20 Jun 2015 01:21:02 -0400 (EDT) X-Virus-Scanned: amavisd-new at egr.msu.edu Received: from mail.egr.msu.edu ([127.0.0.1]) by boomhauer (boomhauer.egr.msu.edu [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Lf-bmuzz5NbR for ; Sat, 20 Jun 2015 01:21:01 -0400 (EDT) Received: from EGR authenticated sender mcdouga9 Message-ID: <5584F83D.1040702@egr.msu.edu> Date: Sat, 20 Jun 2015 01:21:01 -0400 From: Adam McDougall User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:31.0) Gecko/20100101 Thunderbird/31.7.0 MIME-Version: 1.0 To: freebsd-fs@freebsd.org Subject: Re: ZFS pool restructuring and emergency repair References: <5584C0BC.9070707@sneakertech.com> In-Reply-To: <5584C0BC.9070707@sneakertech.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: freebsd-fs@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: Filesystems List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 20 Jun 2015 05:21:10 -0000 On 06/19/2015 21:24, Quartz wrote: > I'm wondering if anyone can help me clear up a few questions and > concerns I have about ZFS. > > It seems to me that ZFS is really not terribly flexible when it comes to > changing a pool's structure after the fact, and once you set something > up you're pretty much stuck with it, making future administration and > repairs complicated. To be fair, I'm not really clear on what all the > available tools can do and what the options are- I haven't really been > keeping up with ZFS development over the past few years so I'm not sure > how much of my knowledge is out of date. > > What are people's responses and recommendations given the following > hypothetical situations: > > - A server is set up with a pool created a certain way. A couple years > later it's determined that the pool configuration wasn't a good choice > for the workload and it should be redone. As I understand it, ZFS has no > capability to reorganize, remove, or re-type vdevs, so your only option > is completely starting over with another whole pool. Is this still true? > If so, is there a correct way to copy an entire pool to another set of > disks in a way that preserves all the metadata and hierarchical dataset > information? (snapshots, noatime, compression, dedupe, quotas, > mountpoints, etc). It looks like 'send' and 'receive' might do it, but > I'm having trouble finding detailed information on exactly what they > copy, how much of a skeleton on the receiving end I need to manually > create first, and what breaks if we have a root-on-ZFS setup. The manpage for zfs says: (under zfs send) -R Generate a replication stream package, which will replicate the specified filesystem, and all descendent file systems, up to the named snapshot. When received, all properties, snap‐ shots, descendent file systems, and clones are preserved. > > > - A server is set up with a pool created a certain way, for the sake of > argument let's say it's a raidz-2 comprised of 6x 2TB disks. There's > only actually ~1TB of data currently on the server though. Let's say > there's a catastrophic emergency where one of the disks needs to be > replaced, but the only available spare is an old 500GB. As I understand > it, you're basically SOL. Even though a 6x500 (really 4x500) is more > than enough to hold 1Tb of data, you can't do anything in this situation > since although ZFS can expand a pool to fit larger disks, it can't > shrink one under any circumstance. Is my understanding still correct or > is there a way around this issue now? man gvirstor which lets you create an arbitrarily large storage device backed by chunks of storage based on how much you are actually using. I have not used it.