[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-id: <20080221092026.GW3029@webber.adilger.int>
Date: Thu, 21 Feb 2008 02:20:26 -0700
From: Andreas Dilger <adilger@....com>
To: Theodore Tso <tytso@....edu>
Cc: linux-ext4@...r.kernel.org
Subject: Re: [PATCH] blkid detection for ZFS
On Feb 20, 2008 07:57 -0500, Theodore Ts'o wrote:
> On Thu, Feb 14, 2008 at 06:07:40PM -0700, Andreas Dilger wrote:
> > Some input is welcome here also... There is a UUID (GUID) for the whole
> > "pool" (aggregation of devices that ZFS filesystems might live on), a
> > UUID for the "virtual device" (vdev) (akin to MD RAID set) that a disk
> > is part of and also a separate UUID for each device. There is a LABEL
> > (pool name) for the whole pool, but not one for an individual filesystem.
>
> Are there devices for that are made available for the vdev and the
> pool? I assume not for the pool since that's a filesystem entity, but
> what about the vdev?
>
> In general, blkid is all about mapping the UUID of what lives on the
> device to the device filename, for the benefit of programs like mount
> and fsck.
>
> I don't know enough about ZFS in terms of how you would mount a
> filesystem which is part of a pool. How is the filesystem specified
> to the "mount" command?
Good question. For Lustre (linux or Solaris), we want to be able to find
the pool by name, and then use ZFS tools to "import" the pool and make the
filesystems available to Lustre. The current ZFS tools (as ported to
Linux) scan all of /dev/* directly, but I'd much prefer to use libblkid
for that since it knows about PVs, RAID devices, etc.
Filesystems in a ZFS pool are specified via "{poolname}/{fsname}", but
to get "fsname" from disk is much more involved than I want to get,
since it almost involves importing the pool and parsing a whole tree
of parameters and indexes.
I'd be pretty happy to just know from "blkid" that a given device is
used by ZFS for "lustrepool" or "fusepool" or whatever it is called.
> So it would seem to me that it would be better to make the UUID be for
> a particular ZFS physical disk be the UUID for that disk, and not for
> the whole pool. The question really, though, is what actually would
> be most useful --- who is going to actually use blkid on a Solaris
> system with ZFS? It may be that the right answer is to put the pool
> UUID as a separate tag; blkid supports more than just the standard
> LABEL, UUID, TYPE, etc. tags. You could easily stash the pool UUID in
> a POOL_GUID tag, if it would be useful for some blkid callers.
OK, maybe I'll go that route, since I won't stricly be having UUIDs
or LABELs that directly map to filesystems.
>
> > On a related note - on Solaris the ZFS filesystems always live in a GPT
> > partition table, and I note that libblkid doesn't identify this. Is that
> > something we want to start adding to libblkid (e.g. GPT, DOS, LVM, etc)?
>
> What do you mean by not identifying the GPT partition table? At the
> moment we haven't been identifying the whole disk partition tables,
> mainly becuase there isn't much use for it especially for the DOS MBR
> (no uuid or label to speak of).
>
> I just checked in a patch from Eric to detect LVM2 PV's, because it
> was useful for the Anaconda developers. I wouldn't have any
> objections accepting a patch which detected the whole-disk device and
> returned the GPT label/UUID information, but I probably wouldn't code
> it myself. Still, if it someone thought it was *useful* and would use
> it, and thus felt called to write a patch, I'd certainly accept it.
That was my question. I didn't see the LVM2 identification patch until
after my email, but this makes it fairly clear that identification of
block devices isn't verboten.
Cheers, Andreas
--
Andreas Dilger
Sr. Staff Engineer, Lustre Group
Sun Microsystems of Canada, Inc.
-
To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists