On Mon, 2008-12-29 at 23:16 +0800, Yan Zheng wrote:
> 2008/12/29 Chris Samuel <ch...@csamuel.org>:
> > Hello Yan,
> >
> > On Mon, 29 Dec 2008 11:33:18 pm Yan Zheng wrote:
> >
> >> 2008/12/29 Chris Samuel <ch...@csamuel.org>:
> >>
> >> > The rebalancing code does appear (from a naive read of the code) to be
> >> > able to rebalance over stripes, but I have no idea if the disk format
> >> > currently supports changing that on the fly.
> >>
> >> The rebalancing moves data/metadata to newly created chunks. If there
> >> are two devices, the new chunks will be set up as RAID-1 by default.
> >
> > Very interesting!  I didn't realise that - I was presuming that the
> > BTRFS_BLOCK_GROUP_RAID1 ioctl needed to be passed through (as at mkfs time) 
> > to
> > change it into a RAID1 array.
> >
> 
> See __btrfs_reserve_extent and __btrfs_alloc_chunk.  There is a mistake in
> my previous reply. Only metadata chunks are set up as RAID-1 by default
> when there are two devices.

This gets confusing in a hurry, but the idea is to duplicate metadata by
default.  So, if you're using the default mount options on a single
drive and add a second drive, it should switch metadata to raid1.

I've always planned on adding an option to btrfs-vol -b to have it
change the data or metadata allocation policies (raidX to raidY,
restripe etc).  The kernel side code is all there, we just need
something to wire it up to userland.

data duplication on a single spindle could work, I just haven't hooked
it up because I couldn't think of a really strong reason to do it ;)

-chris


--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to