
On 10/13/2015 09:59 PM, Eric Blake wrote:
On 10/13/2015 09:46 PM, Nathan Shearer wrote:
I have a script that performs a backup with the following steps:
virsh dumpxml --inactive "$DOMAIN" > "$TMP/${DOMAIN}.xml" && \ virsh dumpxml --inactive "$DOMAIN" > "$DESTINATION_XML" && \ virsh undefine "$DOMAIN" && \ virsh blockcopy "$DOMAIN" "$SOURCE_DISK" "$DESTINATION_DISK" --wait --verbose --finish && \ virsh define "$TMP/${DOMAIN}.xml"
It's basic and did work for creating basic backups. Is there a way to do this without undefining the domain? Not yet. Qemu doesn't yet support persistent bitmaps; there is upstream work trying to add it, which might make qemu 2.5, and then libvirt has to be taught to use it.
I recently had to redefine the VM from a backup XML because this script failed during the block copy step. Why can't I blockcopy a domain that is defined? Why does it need to be undefined first?
Without a persistent bitmap, libvirt cannot restart a copy operation efficiently. Requiring the domain to be transient (via the undefine/define wrapper around the blockcopy) was a design decision made when blockcopy was first added to make the caller aware of the limitations, and put the caller in charge of what happens if the domain disappears in the middle of the operation. We hope to lift that limitation when support for persistent bitmaps lands.
Okay, I'll just make my script a little more intelligent while I wait for the newer versions. Definitely looking forward to qemu 2.5 and an updated libvirt :)