2 Copyright (C) 2017 Red Hat Inc.
4 This work is licensed under the terms of the GNU GPL, version 2 or
5 later. See the COPYING file in the top-level directory.
7 .. _Live Block Operations:
9 ============================
10 Live Block Device Operations
11 ============================
13 QEMU Block Layer currently (as of QEMU 2.9) supports four major kinds of
14 live block device jobs -- stream, commit, mirror, and backup. These can
15 be used to manipulate disk image chains to accomplish certain tasks,
16 namely: live copy data from backing files into overlays; shorten long
17 disk image chains by merging data from overlays into backing files; live
18 synchronize data from a disk image chain (including current active disk)
19 to another target image; and point-in-time (and incremental) backups of
20 a block device. Below is a description of the said block (QMP)
21 primitives, and some (non-exhaustive list of) examples to illustrate
25 The file ``qapi/block-core.json`` in the QEMU source tree has the
26 canonical QEMU API (QAPI) schema documentation for the QMP
27 primitives discussed here.
29 .. todo (kashyapc):: Remove the ".. contents::" directive when Sphinx is
34 Disk image backing chain notation
35 ---------------------------------
37 A simple disk image chain. (This can be created live using QMP
38 ``blockdev-snapshot-sync``, or offline via ``qemu-img``)::
47 (backing file) (overlay)
49 The arrow can be read as: Image [A] is the backing file of disk image
50 [B]. And live QEMU is currently writing to image [B], consequently, it
51 is also referred to as the "active layer".
53 There are two kinds of terminology that are common when referring to
54 files in a disk image backing chain:
56 (1) Directional: 'base' and 'top'. Given the simple disk image chain
57 above, image [A] can be referred to as 'base', and image [B] as
58 'top'. (This terminology can be seen in the QAPI schema file,
61 (2) Relational: 'backing file' and 'overlay'. Again, taking the same
62 simple disk image chain from the above, disk image [A] is referred
63 to as the backing file, and image [B] as overlay.
65 Throughout this document, we will use the relational terminology.
68 The overlay files can generally be any format that supports a
69 backing file, although QCOW2 is the preferred format and the one
70 used in this document.
73 Brief overview of live block QMP primitives
74 -------------------------------------------
76 The following are the four different kinds of live block operations that
77 QEMU block layer supports.
79 (1) ``block-stream``: Live copy of data from backing files into overlay
82 .. note:: Once the 'stream' operation has finished, three things to
85 (a) QEMU rewrites the backing chain to remove
86 reference to the now-streamed and redundant backing
89 (b) the streamed file *itself* won't be removed by QEMU,
90 and must be explicitly discarded by the user;
92 (c) the streamed file remains valid -- i.e. further
93 overlays can be created based on it. Refer the
94 ``block-stream`` section further below for more
97 (2) ``block-commit``: Live merge of data from overlay files into backing
98 files (with the optional goal of removing the overlay file from the
99 chain). Since QEMU 2.0, this includes "active ``block-commit``"
100 (i.e. merge the current active layer into the base image).
102 .. note:: Once the 'commit' operation has finished, there are three
103 things to note here as well:
105 (a) QEMU rewrites the backing chain to remove reference
106 to now-redundant overlay images that have been
107 committed into a backing file;
109 (b) the committed file *itself* won't be removed by QEMU
110 -- it ought to be manually removed;
112 (c) however, unlike in the case of ``block-stream``, the
113 intermediate images will be rendered invalid -- i.e.
114 no more further overlays can be created based on
115 them. Refer the ``block-commit`` section further
116 below for more details.
118 (3) ``drive-mirror`` (and ``blockdev-mirror``): Synchronize a running
119 disk to another image.
121 (4) ``blockdev-backup`` (and the deprecated ``drive-backup``):
122 Point-in-time (live) copy of a block device to a destination.
125 .. _`Interacting with a QEMU instance`:
127 Interacting with a QEMU instance
128 --------------------------------
130 To show some example invocations of command-line, we will use the
131 following invocation of QEMU, with a QMP server running over UNIX
136 $ |qemu_system| -display none -no-user-config -nodefaults \\
138 node-name=node-A,driver=qcow2,file.driver=file,file.node-name=file,file.filename=./a.qcow2 \\
139 -device virtio-blk,drive=node-A,id=virtio0 \\
140 -monitor stdio -qmp unix:/tmp/qmp-sock,server=on,wait=off
142 The ``-blockdev`` command-line option, used above, is available from
143 QEMU 2.9 onwards. In the above invocation, notice the ``node-name``
144 parameter that is used to refer to the disk image a.qcow2 ('node-A') --
145 this is a cleaner way to refer to a disk image (as opposed to referring
146 to it by spelling out file paths). So, we will continue to designate a
147 ``node-name`` to each further disk image created (either via
148 ``blockdev-snapshot-sync``, or ``blockdev-add``) as part of the disk
149 image chain, and continue to refer to the disks using their
150 ``node-name`` (where possible, because ``block-commit`` does not yet, as
151 of QEMU 2.9, accept ``node-name`` parameter) when performing various
154 To interact with the QEMU instance launched above, we will use the
155 ``qmp-shell`` utility (located at: ``qemu/scripts/qmp``, as part of the
156 QEMU source directory), which takes key-value pairs for QMP commands.
157 Invoke it as below (which will also print out the complete raw JSON
158 syntax for reference -- examples in the following sections)::
160 $ ./qmp-shell -v -p /tmp/qmp-sock
164 In the event we have to repeat a certain QMP command, we will: for
165 the first occurrence of it, show the ``qmp-shell`` invocation, *and*
166 the corresponding raw JSON QMP syntax; but for subsequent
167 invocations, present just the ``qmp-shell`` syntax, and omit the
168 equivalent JSON output.
171 Example disk image chain
172 ------------------------
174 We will use the below disk image chain (and occasionally spelling it
175 out where appropriate) when discussing various primitives::
177 [A] <-- [B] <-- [C] <-- [D]
179 Where [A] is the original base image; [B] and [C] are intermediate
180 overlay images; image [D] is the active layer -- i.e. live QEMU is
181 writing to it. (The rule of thumb is: live QEMU will always be pointing
182 to the rightmost image in a disk image chain.)
184 The above image chain can be created by invoking
185 ``blockdev-snapshot-sync`` commands as following (which shows the
186 creation of overlay image [B]) using the ``qmp-shell`` (our invocation
187 also prints the raw JSON invocation of it)::
189 (QEMU) blockdev-snapshot-sync node-name=node-A snapshot-file=b.qcow2 snapshot-node-name=node-B format=qcow2
191 "execute": "blockdev-snapshot-sync",
193 "node-name": "node-A",
194 "snapshot-file": "b.qcow2",
196 "snapshot-node-name": "node-B"
200 Here, "node-A" is the name QEMU internally uses to refer to the base
201 image [A] -- it is the backing file, based on which the overlay image,
204 To create the rest of the overlay images, [C], and [D] (omitting the raw
205 JSON output for brevity)::
207 (QEMU) blockdev-snapshot-sync node-name=node-B snapshot-file=c.qcow2 snapshot-node-name=node-C format=qcow2
208 (QEMU) blockdev-snapshot-sync node-name=node-C snapshot-file=d.qcow2 snapshot-node-name=node-D format=qcow2
211 A note on points-in-time vs file names
212 --------------------------------------
214 In our disk image chain::
216 [A] <-- [B] <-- [C] <-- [D]
218 We have *three* points in time and an active layer:
220 - Point 1: Guest state when [B] was created is contained in file [A]
221 - Point 2: Guest state when [C] was created is contained in [A] + [B]
222 - Point 3: Guest state when [D] was created is contained in
224 - Active layer: Current guest state is contained in [A] + [B] + [C] +
227 Therefore, be aware with naming choices:
229 - Naming a file after the time it is created is misleading -- the
230 guest data for that point in time is *not* contained in that file
231 (as explained earlier)
232 - Rather, think of files as a *delta* from the backing file
235 Live block streaming --- ``block-stream``
236 -----------------------------------------
238 The ``block-stream`` command allows you to do live copy data from backing
239 files into overlay images.
241 Given our original example disk image chain from earlier::
243 [A] <-- [B] <-- [C] <-- [D]
245 The disk image chain can be shortened in one of the following different
246 ways (not an exhaustive list).
250 (1) Merge everything into the active layer: I.e. copy all contents from
251 the base image, [A], and overlay images, [B] and [C], into [D],
252 *while* the guest is running. The resulting chain will be a
253 standalone image, [D] -- with contents from [A], [B] and [C] merged
254 into it (where live QEMU writes go to)::
260 (2) Taking the same example disk image chain mentioned earlier, merge
261 only images [B] and [C] into [D], the active layer. The result will
262 be contents of images [B] and [C] will be copied into [D], and the
263 backing file pointer of image [D] will be adjusted to point to image
264 [A]. The resulting chain will be::
270 (3) Intermediate streaming (available since QEMU 2.8): Starting afresh
271 with the original example disk image chain, with a total of four
272 images, it is possible to copy contents from image [B] into image
273 [C]. Once the copy is finished, image [B] can now be (optionally)
274 discarded; and the backing file pointer of image [C] will be
275 adjusted to point to [A]. I.e. after performing "intermediate
276 streaming" of [B] into [C], the resulting image chain will be (where
277 live QEMU is writing to [D])::
282 QMP invocation for ``block-stream``
283 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
285 For `Case-1`_, to merge contents of all the backing files into the
286 active layer, where 'node-D' is the current active image (by default
287 ``block-stream`` will flatten the entire chain); ``qmp-shell`` (and its
288 corresponding JSON output)::
290 (QEMU) block-stream device=node-D job-id=job0
292 "execute": "block-stream",
299 For `Case-2`_, merge contents of the images [B] and [C] into [D], where
300 image [D] ends up referring to image [A] as its backing file::
302 (QEMU) block-stream device=node-D base-node=node-A job-id=job0
304 And for `Case-3`_, of "intermediate" streaming", merge contents of
305 images [B] into [C], where [C] ends up referring to [A] as its backing
308 (QEMU) block-stream device=node-C base-node=node-A job-id=job0
310 Progress of a ``block-stream`` operation can be monitored via the QMP
313 (QEMU) query-block-jobs
315 "execute": "query-block-jobs",
320 Once the ``block-stream`` operation has completed, QEMU will emit an
321 event, ``BLOCK_JOB_COMPLETED``. The intermediate overlays remain valid,
322 and can now be (optionally) discarded, or retained to create further
323 overlays based on them. Finally, the ``block-stream`` jobs can be
324 restarted at anytime.
327 Live block commit --- ``block-commit``
328 --------------------------------------
330 The ``block-commit`` command lets you merge live data from overlay
331 images into backing file(s). Since QEMU 2.0, this includes "live active
332 commit" (i.e. it is possible to merge the "active layer", the right-most
333 image in a disk image chain where live QEMU will be writing to, into the
334 base image). This is analogous to ``block-stream``, but in the opposite
337 Again, starting afresh with our example disk image chain, where live
338 QEMU is writing to the right-most image in the chain, [D]::
340 [A] <-- [B] <-- [C] <-- [D]
342 The disk image chain can be shortened in one of the following ways:
344 .. _`block-commit_Case-1`:
346 (1) Commit content from only image [B] into image [A]. The resulting
347 chain is the following, where image [C] is adjusted to point at [A]
348 as its new backing file::
352 (2) Commit content from images [B] and [C] into image [A]. The
353 resulting chain, where image [D] is adjusted to point to image [A]
354 as its new backing file::
358 .. _`block-commit_Case-3`:
360 (3) Commit content from images [B], [C], and the active layer [D] into
361 image [A]. The resulting chain (in this case, a consolidated single
366 (4) Commit content from image only image [C] into image [B]. The
371 (5) Commit content from image [C] and the active layer [D] into image
372 [B]. The resulting chain::
377 QMP invocation for ``block-commit``
378 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
380 For :ref:`Case-1 <block-commit_Case-1>`, to merge contents only from
381 image [B] into image [A], the invocation is as follows::
383 (QEMU) block-commit device=node-D base=a.qcow2 top=b.qcow2 job-id=job0
385 "execute": "block-commit",
394 Once the above ``block-commit`` operation has completed, a
395 ``BLOCK_JOB_COMPLETED`` event will be issued, and no further action is
396 required. As the end result, the backing file of image [C] is adjusted
397 to point to image [A], and the original 4-image chain will end up being
403 The intermediate image [B] is invalid (as in: no more further
404 overlays based on it can be created).
406 Reasoning: An intermediate image after a 'stream' operation still
407 represents that old point-in-time, and may be valid in that context.
408 However, an intermediate image after a 'commit' operation no longer
409 represents any point-in-time, and is invalid in any context.
412 However, :ref:`Case-3 <block-commit_Case-3>` (also called: "active
413 ``block-commit``") is a *two-phase* operation: In the first phase, the
414 content from the active overlay, along with the intermediate overlays,
415 is copied into the backing file (also called the base image). In the
416 second phase, adjust the said backing file as the current active image
417 -- possible via issuing the command ``block-job-complete``. Optionally,
418 the ``block-commit`` operation can be cancelled by issuing the command
419 ``block-job-cancel``, but be careful when doing this.
421 Once the ``block-commit`` operation has completed, the event
422 ``BLOCK_JOB_READY`` will be emitted, signalling that the synchronization
423 has finished. Now the job can be gracefully completed by issuing the
424 command ``block-job-complete`` -- until such a command is issued, the
425 'commit' operation remains active.
427 The following is the flow for :ref:`Case-3 <block-commit_Case-3>` to
428 convert a disk image chain such as this::
430 [A] <-- [B] <-- [C] <-- [D]
436 Where content from all the subsequent overlays, [B], and [C], including
437 the active layer, [D], is committed back to [A] -- which is where live
438 QEMU is performing all its current writes).
440 Start the "active ``block-commit``" operation::
442 (QEMU) block-commit device=node-D base=a.qcow2 top=d.qcow2 job-id=job0
444 "execute": "block-commit",
454 Once the synchronization has completed, the event ``BLOCK_JOB_READY`` will
457 Then, optionally query for the status of the active block operations.
458 We can see the 'commit' job is now ready to be completed, as indicated
459 by the line *"ready": true*::
461 (QEMU) query-block-jobs
463 "execute": "query-block-jobs",
482 Gracefully complete the 'commit' block device job::
484 (QEMU) block-job-complete device=job0
486 "execute": "block-job-complete",
495 Finally, once the above job is completed, an event
496 ``BLOCK_JOB_COMPLETED`` will be emitted.
499 The invocation for rest of the cases (2, 4, and 5), discussed in the
500 previous section, is omitted for brevity.
503 Live disk synchronization --- ``drive-mirror`` and ``blockdev-mirror``
504 ----------------------------------------------------------------------
506 Synchronize a running disk image chain (all or part of it) to a target
509 Again, given our familiar disk image chain::
511 [A] <-- [B] <-- [C] <-- [D]
513 The ``drive-mirror`` (and its newer equivalent ``blockdev-mirror``)
514 allows you to copy data from the entire chain into a single target image
515 (which can be located on a different host), [E].
519 When you cancel an in-progress 'mirror' job *before* the source and
520 target are synchronized, ``block-job-cancel`` will emit the event
521 ``BLOCK_JOB_CANCELLED``. However, note that if you cancel a
522 'mirror' job *after* it has indicated (via the event
523 ``BLOCK_JOB_READY``) that the source and target have reached
524 synchronization, then the event emitted by ``block-job-cancel``
525 changes to ``BLOCK_JOB_COMPLETED``.
527 Besides the 'mirror' job, the "active ``block-commit``" is the only
528 other block device job that emits the event ``BLOCK_JOB_READY``.
529 The rest of the block device jobs ('stream', "non-active
530 ``block-commit``", and 'backup') end automatically.
532 So there are two possible actions to take, after a 'mirror' job has
533 emitted the event ``BLOCK_JOB_READY``, indicating that the source and
534 target have reached synchronization:
536 (1) Issuing the command ``block-job-cancel`` (after it emits the event
537 ``BLOCK_JOB_COMPLETED``) will create a point-in-time (which is at
538 the time of *triggering* the cancel command) copy of the entire disk
539 image chain (or only the top-most image, depending on the ``sync``
540 mode), contained in the target image [E]. One use case for this is
541 live VM migration with non-shared storage.
543 (2) Issuing the command ``block-job-complete`` (after it emits the event
544 ``BLOCK_JOB_COMPLETED``) will adjust the guest device (i.e. live
545 QEMU) to point to the target image, [E], causing all the new writes
546 from this point on to happen there.
548 About synchronization modes: The synchronization mode determines
549 *which* part of the disk image chain will be copied to the target.
550 Currently, there are four different kinds:
552 (1) ``full`` -- Synchronize the content of entire disk image chain to
555 (2) ``top`` -- Synchronize only the contents of the top-most disk image
556 in the chain to the target
558 (3) ``none`` -- Synchronize only the new writes from this point on.
560 .. note:: In the case of ``blockdev-backup`` (or deprecated
561 ``drive-backup``), the behavior of ``none``
562 synchronization mode is different. Normally, a
563 ``backup`` job consists of two parts: Anything that is
564 overwritten by the guest is first copied out to the
565 backup, and in the background the whole image is copied
566 from start to end. With ``sync=none``, it's only the
569 (4) ``incremental`` -- Synchronize content that is described by the
573 Refer to the :doc:`bitmaps` document in the QEMU source
574 tree to learn about the detailed workings of the ``incremental``
575 synchronization mode.
578 QMP invocation for ``drive-mirror``
579 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
581 To copy the contents of the entire disk image chain, from [A] all the
582 way to [D], to a new target (``drive-mirror`` will create the destination
583 file, if it doesn't already exist), call it [E]::
585 (QEMU) drive-mirror device=node-D target=e.qcow2 sync=full job-id=job0
587 "execute": "drive-mirror",
596 The ``"sync": "full"``, from the above, means: copy the *entire* chain
599 Following the above, querying for active block jobs will show that a
600 'mirror' job is "ready" to be completed (and QEMU will also emit an
601 event, ``BLOCK_JOB_READY``)::
603 (QEMU) query-block-jobs
605 "execute": "query-block-jobs",
624 And, as noted in the previous section, there are two possible actions
627 (a) Create a point-in-time snapshot by ending the synchronization. The
628 point-in-time is at the time of *ending* the sync. (The result of
629 the following being: the target image, [E], will be populated with
630 content from the entire chain, [A] to [D])::
632 (QEMU) block-job-cancel device=job0
634 "execute": "block-job-cancel",
640 (b) Or, complete the operation and pivot the live QEMU to the target
643 (QEMU) block-job-complete device=job0
645 In either of the above cases, if you once again run the
646 ``query-block-jobs`` command, there should not be any active block
649 Comparing 'commit' and 'mirror': In both then cases, the overlay images
650 can be discarded. However, with 'commit', the *existing* base image
651 will be modified (by updating it with contents from overlays); while in
652 the case of 'mirror', a *new* target image is populated with the data
653 from the disk image chain.
656 QMP invocation for live storage migration with ``drive-mirror`` + NBD
657 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
659 Live storage migration (without shared storage setup) is one of the most
660 common use-cases that takes advantage of the ``drive-mirror`` primitive
661 and QEMU's built-in Network Block Device (NBD) server. Here's a quick
662 walk-through of this setup.
664 Given the disk image chain::
666 [A] <-- [B] <-- [C] <-- [D]
668 Instead of copying content from the entire chain, synchronize *only* the
669 contents of the *top*-most disk image (i.e. the active layer), [D], to a
670 target, say, [TargetDisk].
673 The destination host must already have the contents of the backing
674 chain, involving images [A], [B], and [C], visible via other means
675 -- whether by ``cp``, ``rsync``, or by some storage array-specific
678 Sometimes, this is also referred to as "shallow copy" -- because only
679 the "active layer", and not the rest of the image chain, is copied to
683 In this example, for the sake of simplicity, we'll be using the same
684 ``localhost`` as both source and destination.
686 As noted earlier, on the destination host the contents of the backing
687 chain -- from images [A] to [C] -- are already expected to exist in some
688 form (e.g. in a file called, ``Contents-of-A-B-C.qcow2``). Now, on the
689 destination host, let's create a target overlay image (with the image
690 ``Contents-of-A-B-C.qcow2`` as its backing file), to which the contents
691 of image [D] (from the source QEMU) will be mirrored to::
693 $ qemu-img create -f qcow2 -b ./Contents-of-A-B-C.qcow2 \
694 -F qcow2 ./target-disk.qcow2
696 And start the destination QEMU (we already have the source QEMU running
697 -- discussed in the section: `Interacting with a QEMU instance`_)
698 instance, with the following invocation. (As noted earlier, for
699 simplicity's sake, the destination QEMU is started on the same host, but
700 it could be located elsewhere):
704 $ |qemu_system| -display none -no-user-config -nodefaults \\
706 node-name=node-TargetDisk,driver=qcow2,file.driver=file,file.node-name=file,file.filename=./target-disk.qcow2 \\
707 -device virtio-blk,drive=node-TargetDisk,id=virtio0 \\
708 -S -monitor stdio -qmp unix:./qmp-sock2,server=on,wait=off \\
709 -incoming tcp:localhost:6666
711 Given the disk image chain on source QEMU::
713 [A] <-- [B] <-- [C] <-- [D]
715 On the destination host, it is expected that the contents of the chain
716 ``[A] <-- [B] <-- [C]`` are *already* present, and therefore copy *only*
717 the content of image [D].
719 (1) [On *destination* QEMU] As part of the first step, start the
720 built-in NBD server on a given host (local host, represented by
723 (QEMU) nbd-server-start addr={"type":"inet","data":{"host":"::","port":"49153"}}
725 "execute": "nbd-server-start",
737 (2) [On *destination* QEMU] And export the destination disk image using
738 QEMU's built-in NBD server::
740 (QEMU) nbd-server-add device=node-TargetDisk writable=true
742 "execute": "nbd-server-add",
744 "device": "node-TargetDisk"
748 (3) [On *source* QEMU] Then, invoke ``drive-mirror`` (NB: since we're
749 running ``drive-mirror`` with ``mode=existing`` (meaning:
750 synchronize to a pre-created file, therefore 'existing', file on the
751 target host), with the synchronization mode as 'top' (``"sync:
754 (QEMU) drive-mirror device=node-D target=nbd:localhost:49153:exportname=node-TargetDisk sync=top mode=existing job-id=job0
756 "execute": "drive-mirror",
761 "target": "nbd:localhost:49153:exportname=node-TargetDisk",
766 (4) [On *source* QEMU] Once ``drive-mirror`` copies the entire data, and the
767 event ``BLOCK_JOB_READY`` is emitted, issue ``block-job-cancel`` to
768 gracefully end the synchronization, from source QEMU::
770 (QEMU) block-job-cancel device=job0
772 "execute": "block-job-cancel",
778 (5) [On *destination* QEMU] Then, stop the NBD server::
780 (QEMU) nbd-server-stop
782 "execute": "nbd-server-stop",
786 (6) [On *destination* QEMU] Finally, resume the guest vCPUs by issuing the
787 QMP command ``cont``::
796 Higher-level libraries (e.g. libvirt) automate the entire above
797 process (although note that libvirt does not allow same-host
798 migrations to localhost for other reasons).
801 Notes on ``blockdev-mirror``
802 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
804 The ``blockdev-mirror`` command is equivalent in core functionality to
805 ``drive-mirror``, except that it operates at node-level in a BDS graph.
807 Also: for ``blockdev-mirror``, the 'target' image needs to be explicitly
808 created (using ``qemu-img``) and attach it to live QEMU via
809 ``blockdev-add``, which assigns a name to the to-be created target node.
811 E.g. the sequence of actions to create a point-in-time backup of an
812 entire disk image chain, to a target, using ``blockdev-mirror`` would be:
814 (0) Create the QCOW2 overlays, to arrive at a backing chain of desired
817 (1) Create the target image (using ``qemu-img``), say, ``e.qcow2``
819 (2) Attach the above created file (``e.qcow2``), run-time, using
820 ``blockdev-add`` to QEMU
822 (3) Perform ``blockdev-mirror`` (use ``"sync": "full"`` to copy the
823 entire chain to the target). And notice the event
826 (4) Optionally, query for active block jobs, there should be a 'mirror'
827 job ready to be completed
829 (5) Gracefully complete the 'mirror' block device job, and notice the
830 event ``BLOCK_JOB_COMPLETED``
832 (6) Shutdown the guest by issuing the QMP ``quit`` command so that
835 (7) Then, finally, compare the contents of the disk image chain, and
836 the target copy with ``qemu-img compare``. You should notice:
837 "Images are identical"
840 QMP invocation for ``blockdev-mirror``
841 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
843 Given the disk image chain::
845 [A] <-- [B] <-- [C] <-- [D]
847 To copy the contents of the entire disk image chain, from [A] all the
848 way to [D], to a new target, call it [E]. The following is the flow.
850 Create the overlay images, [B], [C], and [D]::
852 (QEMU) blockdev-snapshot-sync node-name=node-A snapshot-file=b.qcow2 snapshot-node-name=node-B format=qcow2
853 (QEMU) blockdev-snapshot-sync node-name=node-B snapshot-file=c.qcow2 snapshot-node-name=node-C format=qcow2
854 (QEMU) blockdev-snapshot-sync node-name=node-C snapshot-file=d.qcow2 snapshot-node-name=node-D format=qcow2
856 Create the target image, [E]::
858 $ qemu-img create -f qcow2 e.qcow2 39M
860 Add the above created target image to QEMU, via ``blockdev-add``::
862 (QEMU) blockdev-add driver=qcow2 node-name=node-E file={"driver":"file","filename":"e.qcow2"}
864 "execute": "blockdev-add",
866 "node-name": "node-E",
870 "filename": "e.qcow2"
875 Perform ``blockdev-mirror``, and notice the event ``BLOCK_JOB_READY``::
877 (QEMU) blockdev-mirror device=node-B target=node-E sync=full job-id=job0
879 "execute": "blockdev-mirror",
888 Query for active block jobs, there should be a 'mirror' job ready::
890 (QEMU) query-block-jobs
892 "execute": "query-block-jobs",
911 Gracefully complete the block device job operation, and notice the
912 event ``BLOCK_JOB_COMPLETED``::
914 (QEMU) block-job-complete device=job0
916 "execute": "block-job-complete",
925 Shutdown the guest, by issuing the ``quit`` QMP command::
934 Live disk backup --- ``blockdev-backup`` and the deprecated``drive-backup``
935 ---------------------------------------------------------------------------
937 The ``blockdev-backup`` (and the deprecated ``drive-backup``) allows
938 you to create a point-in-time snapshot.
940 In this case, the point-in-time is when you *start* the
941 ``blockdev-backup`` (or deprecated ``drive-backup``) command.
944 QMP invocation for ``drive-backup``
945 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
947 Note that ``drive-backup`` command is deprecated since QEMU 6.2 and
948 will be removed in future.
950 Yet again, starting afresh with our example disk image chain::
952 [A] <-- [B] <-- [C] <-- [D]
954 To create a target image [E], with content populated from image [A] to
955 [D], from the above chain, the following is the syntax. (If the target
956 image does not exist, ``drive-backup`` will create it)::
958 (QEMU) drive-backup device=node-D sync=full target=e.qcow2 job-id=job0
960 "execute": "drive-backup",
969 Once the above ``drive-backup`` has completed, a ``BLOCK_JOB_COMPLETED`` event
970 will be issued, indicating the live block device job operation has
971 completed, and no further action is required.
974 Moving from the deprecated ``drive-backup`` to newer ``blockdev-backup``
975 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
977 ``blockdev-backup`` differs from ``drive-backup`` in how you specify
978 the backup target. With ``blockdev-backup`` you can't specify filename
979 as a target. Instead you use ``node-name`` of existing block node,
980 which you may add by ``blockdev-add`` or ``blockdev-create`` commands.
981 Correspondingly, ``blockdev-backup`` doesn't have ``mode`` and
982 ``format`` arguments which don't apply to an existing block node. See
983 following sections for details and examples.
986 Notes on ``blockdev-backup``
987 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
989 The ``blockdev-backup`` command operates at node-level in a Block Driver
992 E.g. the sequence of actions to create a point-in-time backup
993 of an entire disk image chain, to a target, using ``blockdev-backup``
996 (0) Create the QCOW2 overlays, to arrive at a backing chain of desired
999 (1) Create the target image (using ``qemu-img``), say, ``e.qcow2``
1001 (2) Attach the above created file (``e.qcow2``), run-time, using
1002 ``blockdev-add`` to QEMU
1004 (3) Perform ``blockdev-backup`` (use ``"sync": "full"`` to copy the
1005 entire chain to the target). And notice the event
1006 ``BLOCK_JOB_COMPLETED``
1008 (4) Shutdown the guest, by issuing the QMP ``quit`` command, so that
1011 (5) Then, finally, compare the contents of the disk image chain, and
1012 the target copy with ``qemu-img compare``. You should notice:
1013 "Images are identical"
1015 The following section shows an example QMP invocation for
1016 ``blockdev-backup``.
1018 QMP invocation for ``blockdev-backup``
1019 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1021 Given a disk image chain of depth 1 where image [B] is the active
1022 overlay (live QEMU is writing to it)::
1026 The following is the procedure to copy the content from the entire chain
1027 to a target image (say, [E]), which has the full content from [A] and
1030 Create the overlay [B]::
1032 (QEMU) blockdev-snapshot-sync node-name=node-A snapshot-file=b.qcow2 snapshot-node-name=node-B format=qcow2
1034 "execute": "blockdev-snapshot-sync",
1036 "node-name": "node-A",
1037 "snapshot-file": "b.qcow2",
1039 "snapshot-node-name": "node-B"
1044 Create a target image that will contain the copy::
1046 $ qemu-img create -f qcow2 e.qcow2 39M
1048 Then add it to QEMU via ``blockdev-add``::
1050 (QEMU) blockdev-add driver=qcow2 node-name=node-E file={"driver":"file","filename":"e.qcow2"}
1052 "execute": "blockdev-add",
1054 "node-name": "node-E",
1058 "filename": "e.qcow2"
1063 Then invoke ``blockdev-backup`` to copy the contents from the entire
1064 image chain, consisting of images [A] and [B] to the target image
1067 (QEMU) blockdev-backup device=node-B target=node-E sync=full job-id=job0
1069 "execute": "blockdev-backup",
1078 Once the above 'backup' operation has completed, the event,
1079 ``BLOCK_JOB_COMPLETED`` will be emitted, signalling successful
1082 Next, query for any active block device jobs (there should be none)::
1084 (QEMU) query-block-jobs
1086 "execute": "query-block-jobs",
1090 Shutdown the guest::
1101 The above step is really important; if forgotten, an error, "Failed
1102 to get shared "write" lock on e.qcow2", will be thrown when you do
1103 ``qemu-img compare`` to verify the integrity of the disk image
1104 with the backup content.
1107 The end result will be the image 'e.qcow2' containing a
1108 point-in-time backup of the disk image chain -- i.e. contents from
1109 images [A] and [B] at the time the ``blockdev-backup`` command was
1112 One way to confirm the backup disk image contains the identical content
1113 with the disk image chain is to compare the backup and the contents of
1114 the chain, you should see "Images are identical". (NB: this is assuming
1115 QEMU was launched with ``-S`` option, which will not start the CPUs at
1118 $ qemu-img compare b.qcow2 e.qcow2
1119 Warning: Image size mismatch!
1120 Images are identical.
1122 NOTE: The "Warning: Image size mismatch!" is expected, as we created the
1123 target image (e.qcow2) with 39M size.