From 355f1a2a7599f25771f390f7dba2f8659dbe8fa6 Mon Sep 17 00:00:00 2001 From: Wido den Hollander Date: Tue, 29 Apr 2014 14:19:03 +0200 Subject: [PATCH] CLOUDSTACK-4549: Do not force RBD snapshot backups to RAW format Since we use qemu-img to copy from RBD to Secondary Storage we no longer have to force to RAW images, but can stick with QCOW2 When the snapshot backups are QCOW2 format they can easily be deployed again when restoring from a backup Conflicts: plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/LibvirtStorageAdaptor.java --- .../hypervisor/kvm/storage/KVMStorageProcessor.java | 10 ++-------- .../kvm/storage/LibvirtStorageAdaptor.java | 13 +++---------- 2 files changed, 5 insertions(+), 18 deletions(-) diff --git a/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/KVMStorageProcessor.java b/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/KVMStorageProcessor.java index 621877e6631..41a7f9f23f6 100644 --- a/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/KVMStorageProcessor.java +++ b/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/KVMStorageProcessor.java @@ -708,7 +708,7 @@ public class KVMStorageProcessor implements StorageProcessor { srcFile.setFormat(PhysicalDiskFormat.RAW); QemuImgFile destFile = new QemuImgFile(snapshotFile); - destFile.setFormat(srcFile.getFormat()); + destFile.setFormat(snapshotDisk.getFormat()); s_logger.debug("Backing up RBD snapshot " + rbdSnapshot + " to " + snapshotFile); QemuImg q = new QemuImg(cmd.getWaitInMillSeconds()); @@ -1230,13 +1230,7 @@ public class KVMStorageProcessor implements StorageProcessor { VolumeObjectTO newVol = new VolumeObjectTO(); newVol.setPath(disk.getName()); newVol.setSize(disk.getVirtualSize()); - - /** - * We have to force the format of RBD volumes to RAW - */ - if (primaryPool.getType() == StoragePoolType.RBD) { - newVol.setFormat(ImageFormat.RAW); - } + newVol.setFormat(ImageFormat.valueOf(disk.getFormat().toString().toUpperCase())); return new CopyCmdAnswer(newVol); } catch (CloudRuntimeException e) { diff --git a/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/LibvirtStorageAdaptor.java b/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/LibvirtStorageAdaptor.java index 699949d08d3..52bbef3d77b 100644 --- a/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/LibvirtStorageAdaptor.java +++ b/plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/LibvirtStorageAdaptor.java @@ -1034,12 +1034,7 @@ public class LibvirtStorageAdaptor implements StorageAdaptor { if (disk.getFormat() == PhysicalDiskFormat.TAR) { newDisk = destPool.createPhysicalDisk(name, PhysicalDiskFormat.DIR, disk.getVirtualSize()); } else { - /* If the source device is on a RBD storage pool force the new disk to the same format (RAW) */ - if (srcPool.getType() != StoragePoolType.RBD) { - newDisk = destPool.createPhysicalDisk(name, disk.getVirtualSize()); - } else { - newDisk = destPool.createPhysicalDisk(name, sourceFormat, disk.getVirtualSize()); - } + newDisk = destPool.createPhysicalDisk(name, disk.getVirtualSize()); } } else { newDisk = new KVMPhysicalDisk(destPool.getSourceDir() + "/" + name, name, destPool); @@ -1089,10 +1084,8 @@ public class LibvirtStorageAdaptor implements StorageAdaptor { } } else if ((srcPool.getType() != StoragePoolType.RBD) && (destPool.getType() == StoragePoolType.RBD)) { /** - * Qemu doesn't support writing to RBD format 2 directly, so we have to write to a temporary RAW file first - * which we then convert to RBD format 2. - * - * A HUGE performance gain can be achieved here if QCOW2 -> RBD format 2 can be done in one step + * Using qemu-img we copy the QCOW2 disk to RAW (on RBD) directly. + * To do so it's mandatory that librbd on the system is at least 0.67.7 (Ceph Dumpling) */ s_logger.debug("The source image is not RBD, but the destination is. We will convert into RBD format 2"); String sourceFile;