This page outlines different situations that a user might encounter when using Coriolis.
No matching migration image type found for OS type ‘windows’
When Replicating/Migrating a Windows VM, the above error can be seen if a Windows template has not been specified for the Temporary migration worker. in the Target options menu, under the Advanced screen, both Linux and Windows templates have to be specified. This is required as Disk cloning is performed using the Linux template and OSMorphing is performed using the Windows template.
Troubleshooting OSMorphing on the Docker-based Coriolis appliance
The OSMorphing process is the procedure undergone by the guest OS being migrated to ensure it will boot on the destination platform.
OSMorphing always occurs on the destination platform, where Coriolis will create a temporary VM (either Linux or Windows, depending on the guest OS being migrated) to perform the OSMorphing steps on the already-synced disks.
Considering that OSMorphing errors may be a direct result of an incompatibility between the specific setup of the guest OS and Coriolis or the destination platform, they are relatively more common during a Migration, and the only concrete way to debug the issues would be to login to the temporary OSMorphing VM Coriolis is controlling to see exactly what Coriolis sees.
Configuration:
There is a dedicated ‘debug_os_morphing_errors’ flag in the ‘[conductor]’ section of /etc/coriolis/coriolis.conf:
debug_os_morphing_errors example
1 2 3 |
# NOTE: this option must be appended within the '[conductor]' section: [conductor] debug_os_morphing_errors = false |
If set to ‘true’, the Coriolis Conductor will skip performing the cleanup steps on the temporary resources on the destination platform and will log out the connection info for the temporary VM in the Coriolis-conductor.log.
NOTE please remember to run a docker restart Coriolis-conductor
for any changes to debug_os_morphing_errors
to take effect.
Accessing the Coriolis temporary worker VM
Below is a sample of the connection info for the temporary worker VM as seen in Coriolis-conductor.log
:
debug_os_morphing_errors log output example
1 2 3 4 5 6 7 8 |
# NOTE: the private keys for the worker VMs may have the passphrase # configured in coriolis.conf set to them: $ grep "temp_keypair_password" /etc/coriolis/coriolis.conf temp_keypair_password = qJDxLBbdFCvRKP3J8qTxcvuh # NOTE: the IP and connection info the temp VM will be logged in the Conductor logs: $ grep "have been cancelled to allow for OSMorphing debugging." /var/log/coriolis/coriolis-conductor.log 2019-10-16 21:53:53.007 WARNING coriolis.conductor.rpc.server [req-05f6b9fa-6d78-45fc-9bee-a1e4de05ac49 ] All subtasks for Migration 'ece4b02d-4ab8-405c-b33e-c36c63a20993' have been cancelled to allow for OSMorphing debugging. The connection info for the worker VM is: {'ip': '138.91.73.150', 'port': 22, 'username': 'coriolis', 'password': None, 'pkey': '<pkey_data>'} |
WARNING if ‘debug_os_morphing_errors’ is set, the lifecycle of the temporary OSMorphing worker VM and all of its associated resources (disks, NICs, public IPs, etc…) will no longer be managed by Coriolis.
All the temporary OSMorphing resources on the destination platform will need to be manually cleaned up after investigations have concluded.
After logging into the temp VM, the following things to check may be of importance:
- if all of the disks of the migrated VM are visible in the temp VM
- if all of the disks are mountable within the temp VM (reviewing
dmesg
output for new mounts is recommended) - if the order of the disks is the same as the order reported by the destination platform’s UI/API
- if the disks are using any non-standard partitioning layouts/formats (ex: BitLocker/dm-crypt, Dynamic Disks on Windows, etc…)
- if Coriolis properly identified and mounted the guest OS being migrated (there should be some non-root mount points on the worker)
- try to run the
chroot
command attempted by Coriolis which leads to the OSMorphing error (can be seen in Coriolis’ error logs)
AWS – 500 Server Error: Internal Server Error for url: https://IP:5566/api/v1/dev/xvdf/acquire
Some AWS instance types use SSD-backing storage, and although the guest OS internally has the disks named /dev/nvmeX
, the AWS API returns the disk labels as /dev/xvdf
.
To overcome this, if the error is encountered when using AWS as a Destination Cloud, consider changing the Instance Type for the Migration Mapping used for the Coriolis Temporary worker.
For example, if the error is seen when using t3.medium, try to use c5.large instead, or other types available, depending on the region.
Change the admin password
The following command can be used to change the password for the admin user:
1 |
$ openstack user set --password-prompt admin |
Once done, consider setting also the corresponding password in /etc/kolla/admin-openrc.sh:
1 |
$ export OS_PASSWORD=YourNewPassword |
For multi-tenant configurations, the following command can be used to change the password for any user:
1 |
$ openstack user set --name admin --domain Default --project admin --project-domain Default --password "new password" admin |
Migrated guest VM fails to boot with a message that root volume or partition not found
A guest VM with the root partition using LABEL paths in /etc/fstab might fail to migrate under Coriolis.
Please refer to the steps to verify and prepare on the source VM before running a migration task, as detailed here: Preparing a VM for migration/replication – Cloudbase Solutions
Once /etc/fstab has been updated on the source VM to use filesystem UUIDs, create a new migration task or an incremental replica.
Windows Server 2012/2012R2 guest OS support
Microsoft Windows Server 2012 and 2012R2 reached End-Of-Life support in October 2023. If upgrading to a newer version before migration is not possible, migrating these versions is subject to best effort.
Coriolis will still handle OS Morphing for these versions, one user consideration is that the older stable such as virtIO drivers 0.1.189 must be used.
Set a static IP for the Coriolis appliance
The Coriolis virtual appliance system is based on the Ubuntu Server, so a typical netplan configuration will apply.
From the console menu, go to the option to edit the network settings.
#vim /etc/netplan/50-cloud-init.yaml
You can set a static IP in this format:
network:
version: 2
ethernets:
enp0s3:
dhcp4: no
addresses: [192.168.0.123/24]
gateway4: 192.168.1.1
nameservers:
addresses: [8.8.8.8,8.8.4.4]
Once the configuration file is saved, exit the Coriolis console edit session by typing “exit”, which will prompt to restart the network services in order to apply the configuration change.