qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] Live Block Migration using Mirroring


From: Marcelo Tosatti
Subject: Re: [Qemu-devel] Live Block Migration using Mirroring
Date: Mon, 5 Mar 2012 13:59:02 -0300
User-agent: Mutt/1.5.21 (2010-09-15)

On Wed, Feb 22, 2012 at 05:13:32PM +0000, Federico Simoncelli wrote:
> Hi,
>  recently I've been working on live block migration combining the live
> snapshots and the blkmirror patch sent by Marcelo Tosatti few months ago.
> 
> The design is summarized at this url as "Mirrored-Snapshot": 
> 
> http://www.ovirt.org/wiki/Features/Design/StorageLiveMigration
> 
> The design assumes that the qemu process can reach both the source and
> destination storages and no real VM migration between hosts is involved.
> The principal problem that it tries to solve is moving a VM to a new
> reachable storage (more space, faster) without temporarily disrupting its
> services.
> 
> The following set of patches are implementing the required changes in
> QEMU.

What is the motivation here? What is the limitation with image streaming
that this tries to solve?

> Here it is a quick example of the use case (for consistency with the
> design at the url above I will use the same step numbers):
> 
> Preparation
> ===========
> 
> $ mkdir /tmp/{src/dst}
> $ qemu-img create -f qcow2 /tmp/src/hd0base.qcow2 20G
> Formatting '/tmp/src/hd0base.qcow2', fmt=qcow2 size=21474836480
> encryption=off cluster_size=65536
> 
> Step 1 - Initital Scenario
> ==========================
> VM1 is running on the src/hd0base. (Where "<=" stands for "uses")
> 
> [src/hd0base] <= VM1(read-write)
> 
> $ qemu-system-x86_64 -hda /tmp/src/hd0base.qcow2 -monitor stdio
> QEMU 1.0.50 monitor - type 'help' for more information
> (qemu)
> 
> Step 3 - Mirrored Live Snapshot
> ===============================
> A mirrored live snapshot is issued using src/hd0snap1 and dst/hd0snap1 as
> image files. (Where "<-" stands for "has backing file")
> 
> [src/hd0base] <- [src/hd0snap1] <= VM1(read-write)
>      ...      <- [dst/hd0snap1] <= VM1(write-only)
> 
> $ qemu-img create -f qcow2 \
>            -b /tmp/src/hd0base.qcow2 /tmp/src/hd0snap1.qcow2 20G
> Formatting '/tmp/src/hd0snap1.qcow2', fmt=qcow2 size=21474836480
> backing_file='/tmp/src/hd0base.qcow2' encryption=off cluster_size=65536
> 
> $ qemu-img create -f qcow2 \
>            -b /tmp/dst/hd0base.qcow2 /tmp/dst/hd0snap1.qcow2 20G
> Formatting '/tmp/dst/hd0snap1.qcow2', fmt=qcow2 size=21474836480
> backing_file='/tmp/src/hd0base.qcow2' encryption=off cluster_size=65536
> 
> (qemu) snapshot_blkdev -n ide0-hd0 \
>          blkmirror:/tmp/src/hd0snap1.qcow2:/tmp/dst/hd0snap1.qcow2 blkmirror
> 
> Step 4 - Backing File Copy
> ==========================
> An external manager copies src/hd0base to the destination dst/hd0base.
> 
> [src/hd0base] <- [src/hd0snap1] <= VM1(read-write)
> [dst/hd0base] <- [dst/hd0snap1] <= VM1(write-only)
> 
> $ cp -a /tmp/src/hd0base.qcow2 /tmp/dst/hd0base.qcow2
> 
> Step 5 - Final Switch to Destination
> ====================================
> VM1 is now able to switch to the destination for both read and write
> operations.
> 
> [src/hd0base] <- [src/hd0snap1] <= VM1(read-write)
> 
> (qemu) snapshot_blkdev -n ide0-hd0 /tmp/dst/hd0snap1.qcow2
> 
> -- 
> Federico



reply via email to

[Prev in Thread] Current Thread [Next in Thread]