[linux-lvm] co-operative snapshots

Jaco Kroon jaco at uls.co.za
Sun Mar 3 11:45:34 UTC 2013


Hi Guys,

I've got a client who wants hourly snapshots for "backup" (rollback
rather) purposes.  Currently it seems each snapshot maintains the fill
difference between the time it was made and the "current" copy.  I was
wondering whether there is a way to get them to co-operate/fork/chain
them or in such a way that every time a write happens not all snapshots
needs to be updated.  Since I really don't know what the concept
should/would be called (or if it even exists) let me describe what I'm
thinking.

As I understand it, a LV is just a logical block - whilst it can consist
of a bunch of smaller blocks it's effectively a linear sequence of bytes.

A snapshot is made by continually copying blocks in the original LV
that's written to into the snapshot and keeping track of which blocks
has been changed.

Let's assume a small LV of 10 blocks.  All the blocks are "0" initially.

Now we immediately create a snapshot (s1), then write a "1" to block 1. 
So now the original block is copied into the snapshot, and the origin LV
is updated.

Now we create another snapshot of the origin LV (s2).  Now, if we write
to block 1 s2 will copy the new data, and s1 will not do anything since
it already made a copy of the block.  If, however we write to block 2
*both* snapshots will copy the block (if I'm not mistaken).  This is
wasteful in terms of resources (for my use case least).

Now, if s1 stopped copying stuff once s2 was made, but somehow indicated
that it's "origin" is now s2 instead of the actual origin, then the
*presented* data from s2 would not change, thus negating the need to
copy further blocks into s1.  Thus effectively if, at the time of
creating s2 I can change the origin of s1 from the original LV to s2
then when block 2 above changes it will *only* be copied to s2, not to
s1 as well.

I know that snapshots of snapshots is possible, but I have no idea how
to use that to achieve the above (if it is even possible).  Basically
every hour currently I create a new snapshot, I keep those for 24 hours,
after which I remove all snapshots where the hour is not divisable by 6,
those I keep for 3 days, after which I keep the 0:00 snapshots for a
week.  After a while the IO to maintain all the identical copies of the
data seem to be getting very significant, and I am hoping there's a way
to reduce that.  Obviously I'd also like to be able to combine two
sequential snapshots.

There are obviously a miriad of impact here, for example, how do you
merge/collapse/remove snapshots, for example, let's I now want to roll
back the original LV to s1 then I'd first need to merge back to s2 and
then I can merge s1.  Like when I have s1, s2 and s3 (in that order)
from LV, then I decide I no longer need s2 - this doesn't affect s3, but
does have impact for s1 - so one would need to collapse/fold s2 into s1
somehow.

In principle I think this would be extremely useful, less wasteful of IO
capacity for my purposes perfect.  There is however one major risk that
I can see, if s2 becomes invalid, then all snapshots that's chained to
it also becomes invalid (s1 in this case).  It should be noted that this
is a MAJOR risk.  I think thin pools would be extremely useful in
combination here so that one can over-allocate the snapshots by a
reasonable margin, and also so that snapshots that becomes chained don't
use more space than actually required.

Opinions please?

-- 
Kind Regards,
Jaco Kroon
-------------- next part --------------
A non-text attachment was scrubbed...
Name: jaco.vcf
Type: text/x-vcard
Size: 231 bytes
Desc: not available
URL: <http://listman.redhat.com/archives/linux-lvm/attachments/20130303/da973975/attachment.vcf>


More information about the linux-lvm mailing list