All of lore.kernel.org
 help / color / mirror / Atom feed
From: Chris Webb <chris@arachsys.com>
To: Yehuda Sadeh Weinraub <yehudasa@gmail.com>,
	Gregory Farnum <gregf@hq.newdream.net>
Cc: ceph-devel@vger.kernel.org
Subject: Re: Cloning rados block devices
Date: Fri, 4 Feb 2011 14:31:41 +0000	[thread overview]
Message-ID: <20110204143140.GG30390@arachsys.com> (raw)
In-Reply-To: <AANLkTinvVJUmwmbw9CwT9wNAjvQXBQLVVP1=LZF5GAGM@mail.gmail.com>

Yehuda Sadeh Weinraub <yehudasa@gmail.com> writes:

> On Mon, Jan 24, 2011 at 6:39 AM, Gregory Farnum <gregf@hq.newdream.net> wrote:
>
> > So with that said, if I were going to implement copy-on-write RBD
> > images, I'd probably do so in the RBD layer rather than via the RADOS
> > commands. Yehuda would have a better idea of how to deal with this
> > than I do, but I'd probably modify the header to store an index
> > indicating the blocks contained in the parent image and which blocks
> > in that range have been written to. Then set up the child image as its
> > own image (with its own header and rados naming scheme, etc) and
> > whenever one block does get written to, copy the object from the
> > parent image to the child's space and mark it as written in the
> > header. I'm not sure how this would impact performance, but presumably
> > most writes would be in areas of the disk not contained in the parent
> > image, and I don't think it would be too difficult to implement. This
> > wouldn't be as space-efficient as cloning for small changes like a
> > config file (since it would modify the whole block, which defaults to
> > 4MB), but I bet it's better than storing 3000 installs of an Ubuntu
> > LTS release.
> 
> Overlaying images is something that we've discussed and considered
> implementing. The easiest way would probably go the way Greg specified
> here in a block granularity. That is, when writing to the overlaying
> image you'd copy the entire block data to that image. Note that it
> isn't required that the overlaying image has the same block size as
> the parent image, so it might make sense to have smaller block sizes
> when doing that. On top of that we can have optimizations (e.g.,
> bitmaps that specify which blocks exist) but that's orthogonal to the
> basic requirements.
> 
> We're in the process of implementing a new userspace library to access
> rbd images (librbd) and probably any new development in that area
> should go through that library once it's ready. The next stages would
> be modifying the qemu-rbd code to use that library, and implementing
> the kernel rbd side.

Thanks Greg and Yehuda for the prompt, detailed and helpful feedback on what
would be needed to implement this feature, and apologies for the slow
follow-up.

When I wrote my original email, I hadn't dug into the underlying structure
of Ceph very much, and didn't realise the implications of implementing this
sort of thing at the RADOS layer, but given the hotspot issues you
highlight, it does sound like implementing in the RBD layer makes much more
sense than trying to use RADOS versioning, as you say.

I suspect that for realistic loads, a 4MB copy-on-write chunk size isn't
going to be particularly evil, especially after the machine has been 'run
in'. I may be able to get a better handle on how block modifications are
distributed with a bit of instrumentation on the block layer on some of our
existing virtual machine images, though... I'll have a play!

Cheers,

Chris.

      reply	other threads:[~2011-02-04 14:32 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-01-23 14:07 Cloning rados block devices Chris Webb
2011-01-24 14:39 ` Gregory Farnum
2011-01-25 23:41   ` Yehuda Sadeh Weinraub
2011-02-04 14:31     ` Chris Webb [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20110204143140.GG30390@arachsys.com \
    --to=chris@arachsys.com \
    --cc=ceph-devel@vger.kernel.org \
    --cc=gregf@hq.newdream.net \
    --cc=yehudasa@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.