zfs: the exponential file system from hell

Lawrence K. Chen, P.Eng. lkchen at ksu.edu
Fri Sep 27 15:00:31 UTC 2013



----- Original Message -----
> On Fri, 27 Sep 2013 14:29:38 +0200, Attila Nagy <bra at fsn.hu> wrote:
> 
> > Hi,
> >
> > Did anyone try to fill a zpool with multiple zfs in it and graph
> > the
> > space accounted by df and zpool list?
> > If not, here it is:
> > https://picasaweb.google.com/104147045962330059540/FreeBSDZfsVsDf#5928271443977601554
> >
> > The zpool in question:
> >          NAME        STATE     READ WRITE CKSUM
> >          mnt         ONLINE       0     0     0
> >            raidz2-0  ONLINE       0     0     0
> >              da1     ONLINE       0     0     0
> >              da2     ONLINE       0     0     0
> >              da3     ONLINE       0     0     0
> >              da4     ONLINE       0     0     0
> >            raidz2-1  ONLINE       0     0     0
> >              da5     ONLINE       0     0     0
> >              da6     ONLINE       0     0     0
> >              da7     ONLINE       0     0     0
> >              da8     ONLINE       0     0     0
> >            raidz2-2  ONLINE       0     0     0
> >              da9     ONLINE       0     0     0
> >              da10    ONLINE       0     0     0
> >              da11    ONLINE       0     0     0
> >              da13    ONLINE       0     0     0
> >
> > And the zfs-es on it:
> > NAME     USED  AVAIL  REFER  MOUNTPOINT
> > mnt     23.3G      0  53.8K  /mnt
> > mnt/p1  3.89G      0  3.89G  /mnt/p1
> > mnt/p2  3.89G      0  3.89G  /mnt/p2
> > mnt/p3  3.89G      0  3.89G  /mnt/p3
> > mnt/p4  3.89G      0  3.89G  /mnt/p4
> > mnt/p5  3.89G      0  3.89G  /mnt/p5
> > mnt/p6  3.89G      0  3.89G  /mnt/p6
> >
> > I have evenly filled the six zfs in 1/100th percents of the full
> > space
> > available, and graphed the results of zpool list's capacity and
> > df's
> > capacity.
> > The x scale is the real space usage in percents.
> >
> > It's quite annoying when df says the file systems are 20% full,
> > while in
> > reality, they are at 60%.
> >
> > Any chance that it will be solved?
> 
> So, if I understand you correctly, you compare the output of free
> space of
> zpool list (of the whole pool) to the output of df of one of size
> zfs's.
> So the conclusion is that zpool list shows you how much space there
> is in
> the pool and df shows the
> amount-of-space-of-one-zfs-if-you-don't-do-change-other-zfs's-in-the-pool-in-the-meantime.
> 
> This is not going to be fixed. It is by design. Choose the best tool
> to
> measure what you want to know.
> But I understand it is a bit confusing if you come from traditional
> fixed-size filesystems.
> You can emulate a fixed-size filesystem by using quota's. Give all
> zfs's
> 1/6 of the space in quota and your df will work perfectly.
> 
> NB: I'm not a ZFS developer so I don't have an authoritative opinion
> about
> all this.
> 
> Regards,
> Ronald.

zpool list gives raw storage space.  Whereas zfs list and df would deal in terms of usable fs space.

And, a given block set, for raidz2, is N data blocks, plus 2 parity blocks, where N+2 <= total disks in vdev.  Which can further complicate the conversion of raw storage to usable. (plus there's additional metadata if you make changes to only some of the data blocks in a block set...and more overhead since the old block set has to stay around until all its data blocks are orphaned.)

-- 
Who: Lawrence K. Chen, P.Eng. - W0LKC - Senior Unix Systems Administrator
For: Enterprise Server Technologies (EST) -- & SafeZone Ally


More information about the freebsd-fs mailing list