[openstack-dev] Proposal for instance-level snapshots in Nova
Jon Bernard
jbernard at tuxion.com
Mon Jan 6 23:50:20 UTC 2014
Hello all,
I would like to propose instance-level snapshots as a feature for
inclusion in Nova. An initial draft of the more official proposal is
here [1], blueprint is here [2].
In a nutshell, this feature will take the existing create-image
functionality a few steps further by providing the ability to take
a snapshot of a running instance that includes all of its attached
volumes. A coordinated snapshot of multiple volumes for backup
purposes. The snapshot operation should occur while the instance is in
a paused and quiesced state so that each volume snapshot is both
consistent within itself and with respect to its sibling snapshots.
I still have some open questions on a few topics:
* API changes, two different approaches come to mind:
1. Nova already has a command `createImage` for creating an image of an
existing instance. This command could be extended to take an
additional parameter `all-volumes` that signals the underlying code
to capture all attached volumes in addition to the root volume. The
semantic here is important, `createImage` is used to create
a template image stored in Glance for later reuse. If the primary
intent of this new feature is for backup only, then it may not be
wise to overlap the two operations in this way. On the other hand,
this approach would introduce the least amount of change to the
existing API, requiring only modification of an existing command
instead of the addition of an entirely new one.
2. If the feature's primary use is for backup purposes, then a new API
call may be a better approach, and leave `createImage` untouched.
This new call could be called `createBackup` and take as a parameter
the name of the instance. Although it introduces a new member to the
API reference, it would allow this feature to evolve without
introducing regressions in any existing calls. These two calls could
share code at some point in the future.
* Existing libvirt support:
To initially support consistent-across-multiple-volumes snapshots,
we must be able to ask libvirt for a snapshot of an already paused
guest. I don't believe such a call is currently supported, so
changes to libvirt may be a prerequisite for this feature.
Any contribution, comments, and pieces of advice are much appreciated.
[1]: https://wiki.openstack.org/wiki/Nova/InstanceLevelSnapshots
[2]: https://blueprints.launchpad.net/nova/+spec/instance-level-snapshots
--
Jon
More information about the OpenStack-dev
mailing list