提交 4d064f97 编写于 作者: P Peter Krempa

kbase: incrementalbackupinternals: Replace bash with pseudocode

Simplify the docs and reduce maintenance burden by just describing the
algorithm by a pseudo-language. Users are encouraged to use libvirt
anyways and projects such as oVirt which do some management of storage
themselves are unlikely to use bash anyways.
Signed-off-by: NPeter Krempa <pkrempa@redhat.com>
Reviewed-by: NEric Blake <eblake@redhat.com>
上级 abf20e65
...@@ -228,42 +228,20 @@ following rules: ...@@ -228,42 +228,20 @@ following rules:
Creating external snapshots manually Creating external snapshots manually
-------------------------------------- --------------------------------------
To create the same topology outside of libvirt (e.g when doing snapshots offline) To create the same topology outside of libvirt (e.g when doing snapshots
a new ``qemu-img`` which supports the ``bitmap`` subcommand is recommended. The offline) the following pseudo-algorithm ensures that the new image after
following algorithm then ensures that the new image after snapshot will work snapshot will work with backups. ``OVERLAY`` corresponds to the new overlay
with backups (note that ``jq`` is a JSON processor): image, ``ACTIVE`` corresponds to the topmost image of the active chain prior to
the snapshot.
:: ::
#!/bin/bash create image OVERLAY on top of ACTIVE
# arguments for each BITMAP in ACTIVE:
SNAP_IMG="vda-2.qcow2" let GRANULARITY = granularity of BITMAP in ACTIVE
BACKING_IMG="vda-1.qcow2"
# constants - snapshots and bitmaps work only with qcow2 if BITMAP isn't RECORDING or is INCONSISTENT:
SNAP_FMT="qcow2" continue
BACKING_IMG_FMT="qcow2"
# create snapshot overlay create RECORDING bitmap named BITMAP in OVERLAY with GRANULARITY
qemu-img create -f "$SNAP_FMT" -F "$BACKING_IMG_FMT" -b "$BACKING_IMG" "$SNAP_IMG"
BACKING_IMG_INFO=$(qemu-img info --output=json -f "$BACKING_IMG_FMT" "$BACKING_IMG")
BACKING_BITMAPS=$(jq '."format-specific".data.bitmaps' <<< "$BACKING_IMG_INFO")
if [ "x$BACKING_BITMAPS" = "xnull" ]; then
exit 0
fi
for BACKING_BITMAP_ in $(jq -c '.[]' <<< "$BACKING_BITMAPS"); do
BITMAP_FLAGS=$(jq -c -r '.flags[]' <<< "$BACKING_BITMAP_")
BITMAP_NAME=$(jq -r '.name' <<< "$BACKING_BITMAP_")
if grep 'in-use' <<< "$BITMAP_FLAGS" ||
grep -v 'auto' <<< "$BITMAP_FLAGS"; then
continue
fi
qemu-img bitmap -f "$SNAP_FMT" "$SNAP_IMG" --add "$BITMAP_NAME"
done
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册