2020-07-22 12:18:55 +02:00
|
|
|
# Snapshot and Restore
|
|
|
|
|
|
|
|
The goal for the snapshot/restore feature is to provide the user with the
|
|
|
|
ability to take a snapshot of a previously paused virtual machine. This
|
|
|
|
snapshot can be used as the base for creating new identical virtual machines,
|
|
|
|
without the need to boot them from scratch. The restore codepath takes the
|
|
|
|
snapshot and creates the exact same virtual machine, restoring the previously
|
|
|
|
saved states. The new virtual machine is restored in a paused state, as it was
|
|
|
|
before the snapshot was performed.
|
|
|
|
|
2021-11-15 14:53:12 +01:00
|
|
|
## Snapshot a Cloud Hypervisor VM
|
2020-07-22 12:18:55 +02:00
|
|
|
|
2021-11-15 14:53:12 +01:00
|
|
|
First thing, we must run a Cloud Hypervisor VM:
|
2020-07-22 12:18:55 +02:00
|
|
|
|
|
|
|
```bash
|
|
|
|
./cloud-hypervisor \
|
|
|
|
--api-socket /tmp/cloud-hypervisor.sock \
|
|
|
|
--cpus boot=4 \
|
|
|
|
--memory size=4G \
|
2021-04-06 10:49:40 +01:00
|
|
|
--kernel vmlinux \
|
2020-07-22 12:18:55 +02:00
|
|
|
--cmdline "root=/dev/vda1 console=hvc0 rw" \
|
|
|
|
--disk path=focal-server-cloudimg-amd64.raw
|
|
|
|
```
|
|
|
|
|
|
|
|
At any point in time when the VM is running, one might choose to pause it:
|
|
|
|
|
|
|
|
```bash
|
2023-09-11 18:32:41 +03:00
|
|
|
./ch-remote --api-socket=/tmp/cloud-hypervisor.sock pause
|
2020-07-22 12:18:55 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
Once paused, the VM can be safely snapshot into the specified directory and
|
|
|
|
using the following command:
|
|
|
|
|
|
|
|
```bash
|
2023-09-11 18:32:41 +03:00
|
|
|
./ch-remote --api-socket=/tmp/cloud-hypervisor.sock snapshot file:///home/foo/snapshot
|
2020-07-22 12:18:55 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
Given the directory was present on the system, the snapshot will succeed and
|
|
|
|
it should contain the following files:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
ll /home/foo/snapshot/
|
|
|
|
total 4194536
|
|
|
|
drwxrwxr-x 2 foo bar 4096 Jul 22 11:50 ./
|
|
|
|
drwxr-xr-x 47 foo bar 4096 Jul 22 11:47 ../
|
2022-02-08 11:32:19 +01:00
|
|
|
-rw------- 1 foo bar 1084 Jul 22 11:19 config.json
|
2022-02-07 11:00:57 +01:00
|
|
|
-rw------- 1 foo bar 4294967296 Jul 22 11:19 memory-ranges
|
2022-02-08 11:32:19 +01:00
|
|
|
-rw------- 1 foo bar 217853 Jul 22 11:19 state.json
|
2020-07-22 12:18:55 +02:00
|
|
|
```
|
|
|
|
|
2022-02-08 11:32:19 +01:00
|
|
|
`config.json` contains the virtual machine configuration. It is used to create
|
|
|
|
a similar virtual machine with the correct amount of CPUs, RAM, and other
|
|
|
|
expected devices. It is stored in a human readable format so that it could be
|
|
|
|
modified between the snapshot and restore phases to achieve some very special
|
|
|
|
use cases. But for most cases, manually modifying the configuration should not
|
|
|
|
be needed.
|
|
|
|
|
2022-02-07 11:00:57 +01:00
|
|
|
`memory-ranges` stores the content of the guest RAM.
|
2020-07-22 12:18:55 +02:00
|
|
|
|
2022-02-08 11:32:19 +01:00
|
|
|
`state.json` contains the virtual machine state. It is used to restore each
|
|
|
|
component in the state it was left before the snapshot occurred.
|
2020-07-22 12:18:55 +02:00
|
|
|
|
2021-11-15 14:53:12 +01:00
|
|
|
## Restore a Cloud Hypervisor VM
|
2020-07-22 12:18:55 +02:00
|
|
|
|
|
|
|
Given that one has access to an existing snapshot in `/home/foo/snapshot`,
|
2024-05-02 08:33:51 +00:00
|
|
|
it is possible to create a new VM based on this snapshot with the following
|
2020-07-22 12:18:55 +02:00
|
|
|
command:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
./cloud-hypervisor \
|
|
|
|
--api-socket /tmp/cloud-hypervisor.sock \
|
|
|
|
--restore source_url=file:///home/foo/snapshot
|
|
|
|
```
|
|
|
|
|
|
|
|
Or using two different commands from two terminals:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
# First terminal
|
|
|
|
./cloud-hypervisor --api-socket /tmp/cloud-hypervisor.sock
|
|
|
|
|
|
|
|
# Second terminal
|
2023-09-11 18:32:41 +03:00
|
|
|
./ch-remote --api-socket=/tmp/cloud-hypervisor.sock restore source_url=file:///home/foo/snapshot
|
2020-07-22 12:18:55 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
Remember the VM is restored in a `paused` state, which was the VM's state when
|
|
|
|
it was snapshot. For this reason, one must explicitly `resume` the VM before to
|
|
|
|
start using it.
|
|
|
|
|
|
|
|
```bash
|
2023-09-11 18:32:41 +03:00
|
|
|
./ch-remote --api-socket=/tmp/cloud-hypervisor.sock resume
|
2020-07-22 12:18:55 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
At this point, the VM is fully restored and is identical to the VM which was
|
|
|
|
snapshot earlier.
|
|
|
|
|
2024-05-02 08:33:51 +00:00
|
|
|
## Restore a VM with new Net FDs
|
|
|
|
For a VM created with FDs explicitly passed to NetConfig, a set of valid FDs
|
|
|
|
need to be provided along with the VM restore command in the following syntax:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
# First terminal
|
|
|
|
./cloud-hypervisor --api-socket /tmp/cloud-hypervisor.sock
|
|
|
|
|
|
|
|
# Second terminal
|
|
|
|
./ch-remote --api-socket=/tmp/cloud-hypervisor.sock restore source_url=file:///home/foo/snapshot net_fds=[net1@[23,24],net2@[25,26]]
|
|
|
|
```
|
|
|
|
In the example above, the net device with id `net1` will be backed by FDs '23'
|
|
|
|
and '24', and the net device with id `net2` will be backed by FDs '25' and '26'
|
|
|
|
from the restored VM.
|
|
|
|
|
2020-07-22 12:18:55 +02:00
|
|
|
## Limitations
|
|
|
|
|
2022-02-07 11:00:57 +01:00
|
|
|
VFIO devices and Intel SGX are out of scope.
|