Ovirtsavior is an old fashioned backup/restore tool for the Ovirt virtualization platform. It can be used to:
- download the disks of a running VM to your local file system (backup mode).
- create snaphot of a VM (backuptemp mode).
- upload the disks of a previously backed up VM to a new Ovirt VM (restore mode).
You can use rclone
to mount a remote directory to your local storage (Google Drive, etc). Use this with caution, it is probably much safer to save it to a local disc or NFS mount.
Ovirtsavior was created due to the support of the Study in Greece initiative.
Use the software at your own risk. This has not been heavily tested in production environments. We suggest running the scripts on Ubuntu 20.04 or directly on node OVS Server. It tested work on Ovirt 4.5 engines.
The tool is used to backup and restore the discs.
- During the backup phase, the discs are downloaded in the working directory along with some rudimentary information regarding the VM parameters.
- In the restore phase, the disks are uploaded to the VM. You need to adjust the VM parameters including memory, CPU cores and also designate bootable disks.
Maybe in a future version we will include this as well.
Some information on the original VM are saved as well in a pickle file inside the VM folder.
All snapshot disks are downloaded during the backup phase in the working directory. However, during the restore phase, the disks are copied to a local temporary directory and the snapshots are collapsed. This practically means that you do not get any previous snapshots in the restored VMs. The reason for this is that we found there may be a bug in the Ovirt API not allowing you to upload intermittent disks with provisioned size lower than the actual size which prevented us from restoring the full snapshot chain. We plan to revisit this in the future.
You need to install qemu-img
and python3-ovirt-engine-sdk4
On Ubuntu 20.04
apt update
apt-get --assume-yes install gcc \
libxml2-dev \
python3-dev \
python3-pip \
libcurl4-openssl-dev \
libssl-dev \
qemu-utils
pip3 install ovirt-engine-sdk-python
On node OVS Server OEL8.10 with OLVM4.5
pip3 install --upgrade pip
pip3 install setuptools-rust
pip3 install paramiko
There are two modes you can use the ovirt-savior
script: backup and restore. In backup mode, you download the VM disks to a local or remote folder. In restore mode, you create a VM using the OVirt API and then upload the discs. You have the option of collapsing the original VM's snapshots on the restored VM and this is probably your safest bet on getting the VM to work again. There seems to be a bug in OVirt that extends the snapshot disc image beyond its maximum size and although this does not affect the original running VM, it prohibits uploading the discs to the restored VMs.
The script creates a temporary snapshot of a running or powered off VM, downloads the disk chains contained in this snapshot and then removes the snapshot
A new VM is created with the same or different name and the disks are uploaded.
python3 ovirt-savior.py [mode] -s [config-file]
It may be a good idea to run this as root when using NFS shares. The mode
option can be either backup
or restore
. The config-file
specifies a configuration file that contains several options.
This is a sample configuration file that can be used for config-file
[CONNECTION]
ca_file : elovirt-pki-resource.cer
username : admin@internal
password : yourpassword
ovirt_url : https://elovirtengine.example.com/ovirt-engine/api
[RESTORATION]
storage_domain : vm_storage
cluster_name : Default
template : Blank
[DIRECTORIES]
local_directory : /tmp
working_directory : /backup
[SNAPSHOT]
backup_snapshot_description : SAVIOR_BACKUP_SNAPSHOT
[SSH]
ssh_ip : ip_address
ssh_username : username_to_connect
ssh_password : user_password
ssh_command_0 : command
ssh_command_1 : command
[TRANSFER]
chunk_size : 1048576
[VM]
vm_name : test_for_backup
new_vm_name : test_for_restore
[MAIL]
smtp_sender : ovirt@example.com
smtp_password : mailpassword
smtp_server : mail.example.com
smtp_port : 587
smtp_recipient : admins@example.com
The following is a brief explanation of the parameters:
ca_file
: the Ovirt engine certificate file. It can be downloaded on the OVirt engine web page.username
: an Ovirt superadmin account username. You must include the domain (e.g. admin@internal).password
: the password of the above account.ovirt_url
: the URL of the Ovirt engine API, should be something in the line of https://elovirtengine.hua.gr/ovirt-engine/api
working_directory
: the directory where the backups will be stored. The script creates a directory for each VM underworking_directory
local_directory
: a directory where the discs are copied before uploaded to Ovirt. Use this in conjunction withcopy_to_local
andcommit
parameters in the restoration section.
This section describes the parameters used during the restoration process.
storage_domain
: the name of the storage domain where the VM will be restored (e.g.vm_storage
).cluster_name
: the name of the cluster where the VM will be restored. (e.g.Default
)template
: you could use this to define a template where the VM is based but since it is restored you should leave it equal toBlank
.
backup_snapshot_description
is the name of a temporary snapshot used to backup VMs (e.g. SAVIOR_BACKUP_SNAPSHOT)
This section describes the parameters used during the backup process. If these parameters are not specified, this section will be skipped.
ssh_ip
: ip address of the vm you want to execute command onssh_username
: username used to connect to this vmssh_password
: password of this userssh_command_0
: commands to execute before adding snapshot to enter backup mode on vmssh_command_1
: commands to finish backup mode
chunk_size
: size of the blocks to be used in the disk transfers in bytes. Usually1048576
is adequate.
mount_remote
: if set toyes
then a remote will be mounted usingrclone
.rclone_remote
: is the name of the remote to be mounted before the backup or restore operation takes place. It will be unmounted once it is done.
vm_name
: the name of the VM to be backed up or restored.new_vm_name
: the new name for the restored VM. It can be different thanvm_name
.
smtp_sender
: Account sending the job notificationssmtp_password
: Account passwordsmtp_server
: E-mail server addresssmtp_port
: Port for communication (e.g. 587)smtp_recipient
: Address receiving email notifications
The file savior.log
located on the same folder as the script, contains a log of current backup and restore jobs. This log is send by e-mail according to the settings of the [MAIL]
section.
One common scenario is when you wish to backup your vm disks on an NFS share. On the NFS remote server you need to install:
apt update
apt install nfs-kernel-server
mkdir /var/nfs/backup -p
chown nobody:nogroup /var/nfs/backup
Create the file /etc/exports
/var/nfs/backup 10.100.59.154(rw,sync,no_subtree_check)
Then do:
ufw allow nfs
systemctl restart nfs-kernel-server
On the NFS client which will execute the ovirt backup scripts you need to install:
apt update
apt install nfs-common
sudo mount 195.130.90.2:/var/nfs/backup /nfs/backup
df -h
To mount the folder at boot append the following line to /etc/fstab
195.130.90.2:/var/nfs/backup /nfs/backup nfs auto,nofail,noatime,nolock,intr,tcp,actimeo=1800 0 0