infra-docs-fpo/modules/sysadmin_guide/pages/virt-notes.adoc
Nils Philippsen b4afb2f945 DC move: iad => rdu3, 10.3. => 10.16.
And remove some obsolete things.

Signed-off-by: Nils Philippsen <nils@redhat.com>
2025-07-04 16:32:42 +02:00

119 lines
4.3 KiB
Text

= Fedora Infrastructure Libvirt Notes
Notes/FAQ on using `libvirt/virsh/virt-manager` in our environment
== How do I migrate a guest from one virthost to another
. Setup an unpassworded root ssh key to allow communication between
the two virthosts as root. This is only temporary, so, while scary it
is not a big deal. Right now, this also means modifying the
`/etc/ssh/sshd_config` to `permitroot without-password`.
. Determine whatever changes need to be made to the guest. This can be
the number of cpus, the amount of memory, or the disk location as this
may not be standard on the current server.
. Make a dump of the current virtual guest using the virsh
command. Use `virsh dumpxml --migratable guestname` and then edit any
changes in disk layout, memory and cpu needed.
. setup storage on the destination end to match the source storage.
`lvs` will give the amount of disk space. Due to some vaguries on disk
sizes, it is always better to round up so if the original server says it
is using 19.85 GB, make the next image 20 GB. On the new server, use
`lvcreate -L+$\{SIZE}GB -n $\{FQDN} vg_guests`
. as root on source location:
+
....
virsh -c qemu:///system migrate --xml ${XML_FILE_FROM_3} \
--copy-storage-all ${GUESTNAME} \
qemu+ssh://root@destinationvirthost/system
This should start the migration process and it will output absolutely
jack-squat on the cli for you to know this. On the destination system
go look in /var/log/libvirt/qemu/myguest.log (tail -f will show you the
progress results as a percentage completed)
....
. Once the migration is complete you will probably need to run this on
the new virthost:
+
....
scp ${XML_FILE_FROM_3} root@destinationvirthost:
ssh root@destinationvirthost
virsh define ${XML_FILE_FROM_3}
virsh autostart ${GUESTNAME}
....
. Edit ansible host_vars of the guest and make sure that the associated
values are correct:
+
....
volgroup: /dev/vg_guests
vmhost: virthost??.phx2.fedoraproject.org
....
. Run the noc.yml ansible playbook to update nagios.
This should work for most systems. However in some cases, the virtual
servers on either side may have too much activity to 'settle' down
enough for a migration to work. In other cases the guest may be on a
disk like ISCSI which may not allow for direct migration. In this case
you will need to use a more direct movement.
[arabic]
. Schedule outage time if any. This will need to be long enough to copy
the data from one host to another, so will depend on guest disk size.
. Turn off monitoring in nagios
. setup an unpassworded root ssh key to allow communication between
the two virthosts as root. This is only temporary, so, while scary it
is not a big deal. Right now, this also means modifying the
`/etc/ssh/sshd_config` to `permitroot without-password`.
. Determine whatever changes need to be made to the guest. This can be
the number of cpus, the amount of memory, or the disk location as this
may not be standard on the current server.
. Make a dump of the current virtual guest using the virsh
command. Use `virsh dumpxml --migratable guestname` and then edit any
changes in disk layout, memory and cpu needed.
. setup storage on the destination end to match the source storage.
`lvs` will give the amount of disk space. Due to some vaguries on disk
sizes, it is always better to round up so if the original server says it
is using 19.85 GB, make the next image 20 GB. On the new server, use
`lvcreate -L+$\{SIZE}GB -n $\{FQDN} vg_guests`
. Shutdown the guest.
. Insert iptables rule for nc transfer:
+
....
iptables -I INPUT 14 -s <source host> -m tcp -p tcp --dport 11111 -j ACCEPT
....
. On the destination host:
+
____
* RHEL-7:
+
....
nc -l 11111 | dd of=/dev/<guest_vg>/<guest-partition>
....
____
. On the source host:
+
....
dd if=/dev/<guest_vg>/<guest-partition> | nc desthost 11111
....
+
Wait for the copy to finish. You can do the following to track how far
something has gone by finding the dd pid and then sending a 'kill -USR1'
to it.
. Once the migration is complete you will probably need to run this on
the new virthost:
+
....
scp ${XML_FILE_FROM_3} root@destinationvirthost:
ssh root@destinationvirthost
virsh define ${XML_FILE_FROM_3}
virsh autostart ${GUESTNAME}
....
. Edit ansible host_vars of the guest and make sure that the associated
values are correct:
+
....
volgroup: /dev/vg_guests
vmhost: virthost??.rdu3.fedoraproject.org
....
. Run the `noc.yml` ansible playbook to update nagios.