How do you clone a VM to another host?
-
I have 2 physical servers (2 hosts)
I want to migrate the VM to the second server as a copy and keep the original one.
I do not have enough space on the disk to copy it, then migrate it.Is there any way to migrate-clone a VM?
thanks
-
@rk9268vc You can
Copy
it to the new host and then start it there. It does not migrate the VM but creates a copy ready to boot while the old one is still running (the copy will be out of date if the VM is still running).You can
Warm migrate
(under the Advanced tab) which gives you the option to Delete (or not) the old VM and Start (or not) the new VM. This option will take a while to complete as it copies the VM and then updates the new VM with the changes during the copy.You can also
Export
the VM and thenImport
it on the new host.If you can shut down the original VM during the copy/migrate process then it will happen a lot faster.
-
@Andrew when i select "copy" it does not give me the option to select the other host, only different disks of the same host.
The other host does show up as a separate pool so i wonder if that is the issue?The VM is around 480 GB and i am moving from a 500GB raid to a 512GB raid so i dont have a lot of wiggle room,
-
Live migration is not possible in this case, because of lack of free space.
You have to shutdown VM, then click this button and chose another host
-
@splastunov Hi. The VM doesnt have to be live migrated, shutdown is fine.
The problem is migrate moves the VM. I want to simply copy the VM to the new machine and keep the instance on the current one.
If I migrate, it will be gone from the current machine.
I do not have the storage space to clone the VM first, then migrate on either host.what i want to do is clone, but to another host, not to the same host - if that makes sense
-
There's a copy button in Xen Orchestra (cf the previous screenshot, in the same bar, the last icon on the right). Copy is a XO feature that will stream the VM to the destination, and in the end make a copy. I suggest you spend some time exploring all XO capabilities, there's many chances it's already covered by existing features
-
@olivierlambert Hi, thanks for the comment.
As mentioned, it does not give me the option to copy to the other host. When I select copy, it only shows the disks of the current host as targets.
The only way that I see to see the other host as a target is with migrate.
Is there a setting or something to be able to see others hosts when copying?
thanks -
XO should list all existing SR (as long as the pool is connected in XO obviously), regardless the pool.
-
I'm having same issue, is there any update to this? I can migrate between hosts but when I hit copy it doesn't allow me to copy between hosts and only shows the host on which it's on.
I have an XENServer host (primary) and XCP-ng (new server). I Can migrate from xenserver to xcp-ng but can't copy for some reason?
-
There is no implementation in XAPI to "copy" VM to remote host (maybe XO has it own implementaion I'm not sure).
Copy works only localy.
You can only migrate it to remote host.Disclaimer.
Everything you do on your own risk.But you can do it manually by export/copy VDI from one host to another.
If you do not need "live" copy while VM is running, just stop VM, get all VBDsxe vbd-list vm-name-lable={VM-name}
.
You will see all VBDs and VDIs of VM.
Go to certain SRcd /var/run/sr-mount/{SR-UUID}
and copy VDI to new host's SR (you can usescp
).
On destination host:- Get new VDI UUID
vhd-util read -p -n {VDI-UUID}.vhd
- Rename file using this UUID
- Rescan SR on destination host.
- Create VM, attach VDI.
If VDI stored on "shared" SR (iSCSI, NFS, ceph rbd and etc...), firts you have to export VDI by command
xe vdi-export uuid={VDI-UUID} filename={VM-Name_xvda}.vhd format=vhd --progress
After success export, copy to destination host, read, rename and etc....If you need "live" migration you can do it with minimal down time via snapshot.
- Make snapshot with uniq name.
- List VBDs
xe vbd-list vm-name-lable={VM-name}
. - Export all VDIs
xe vdi-export uuid={VDI-UUID} filename={VM-Name_xvda}.vhd format=vhd --progress
(repeat for all VDIs). - Copy to destination host
- Use vhd-util to get new UUID and rename VDI
vhd-util read -p -n {VDI-UUID}.vhd
- Shutdown VM. Do not delete VM before it will not start successfully on "new" host!
- Get snapshot list
xe snapshot-list
- Get disks in snapshot
xe snapshot-disk-list uuid={snapshot_UUID}
- Export diff
xe vdi-export uuid={main_VDI_UUID_from_step_3} filename=2920_delta_xvda.vhd format=vhd base={snapshot_VDI_UUID_from_step_8)} --progress
- Copy diff to destination host
- Import diff
xe vdi-import uuid=VDI_UUID_from_step_5 filename=2920_delta_xvda.vhd format=vhd --progress
- Get new VDI UUID
-
The simple answer here is to use the Continuous Replication backup type. It'll copy the VM to another host on whatever schedule you set.
It couldn't be simpler.