How to move data volume between VMs using OpenStack CLI on ESA HPC

Volumes are used to store data and those data can be accessed from a virtual machine to which the volume is attached. To access data stored on a volume from another virtual machine, you need to disconnect that volume from virtual machine to which it is currently connected, and connect it to another instance.

This article uses OpenStack CLI client to transfer volumes between virtual machines which are in the same project.

Prerequisites

No. 1 Hosting

You need a ESA HPC hosting account with Horizon interface https://horizon.eohpc.net/auth/login/?next=/.

No. 2 OpenStack CLI client

To be able to use the OpenStack CLI client, you need to have it installed. One of these articles should help:

You also need to be able to authenticate to the cloud:

How to activate OpenStack CLI access to ESA HPC cloud

No. 3 Source virtual machine and volume

We assume that you have a virtual machine (which we will call source virtual machine) to which a volume is attached.

No. 4 Destination virtual machine

We also assume that you want to access the data stored on volume mentioned in Prerequisite No. 3 from another instance which is in the same project - we will call that instance destination virtual machine.

What We Are Going To Cover

  • Ensure that the transfer is possible

    • Projects must be on the same cloud

    • Volume cannot be used for booting an operating system

    • File system compatibility

    • Making sure that the source virtual machine does not try to access the volume

    • Other volume and instance conditions for successful transfer

  • Obtaining information about the volume

  • Obtaining information about the virtual machines

  • General concerns about shutting down a virtual machine

  • Shutting down the source virtual machine using OpenStack CLI

  • Disconnecting volume

  • Attaching volume to the destination virtual machine

Some parts of some screenshots in this article are greyed out for privacy reasons.

Ensure that the transfer is possible

Before the actual transfer, you have to examine the state of the volume and of the instances and conclude whether the transfer is possible right away or should you perform other operations first:

Projects must be on the same cloud

If the projects are not on the same cloud, do not use this article but see one of these articles instead:

Volume cannot be used for booting an operating system

If a volume is not being used to boot an operating system on a virtual machine, this requirement is fulfilled.

If, however, a volume is being used for booting an operating system, you can convert it to a regular volume.

Converting boot volume to a regular volume will save the day if the operating system on the volume starts malfunctioning and it is imperative to at least save the data; just attach the regular version of that volume to another virtual machine and copy the data.

If you have converted this volume and all other conditions listed in section Ensure that the transfer is possible are met, you don’t have to disconnect the volume from the virtual machine and can ignore parts of the article involving this process.

File system compatibility

To be able to access the data, the file system on the volume must be compatible with the file system in the destination virtual machine.

The easiest case is when NTFS file system is used because both Windows and Linux can access data in that format. This is not guaranteed, so you may be required to install additional drivers for compatibility.

Also note that Windows does not support format ext4, which is a file system commonly used on Linux, by default.

Making sure that the source virtual machine does not try to access the volume

You need to make sure that the source virtual machine does not try to access the volume again.

The exact steps will vary between operating systems and are outside of scope of this article. They might include:

  • removing the volume from /etc/fstab file

  • removing the systemd .mount file

and so on.

Other volume and instance conditions for successful transfer

The volume must:

  • be connected to a virtual machine,

  • have status in-use and not, say, error or another and

  • not be used by any instance to boot an operating system from it.

The instance must be:

  • either turned on or off and

  • not be in another status such as error, shelved or paused.

To learn more about different states in which a virtual machine can be, see /cloud/Status-Power-State-and-dependences-in-billing-of-instances-VMs-on-ESA-HPC

If all these conditions are met, here is how to transfer volume from source instance to the destination instance in the same project.

Obtaining information about the volume

Execute this command to list volumes:

openstack volume list

For each volume, you should see its ID, name, information to which virtual machine it is attached, and so on:

../_images/how-to-move-data-volume-cli-12_creodias.png

In this example, we can see that the volume which we want to move, called volume-to-move, is attached to a virtual machine called previous-vm (orange rectangle). Its ID, marked with a red rectangle, is as follows: 851a3a86-d569-44e4-8c17-f3907af88500.

Other information shown here includes status of the volume (here marked with a green rectangle).

Write somewhere down the ID of the volume you want to move as you will need it later.

Obtaining information about the virtual machines

Execute this command to list servers:

openstack server list

You should see the list of your virtual machines:

../_images/how-to-move-data-volume-cli-31_creodias.png

In this example, we want to move the volume from the source VM which is here called previous-vm. Its ID is b9f2017b-d8f2-420d-a0cb-36867228f17e - on the screenshot it is marked with a red rectangle. The destination VM is called newer-vm. Its ID is 97018102-1706-43e3-933b-60e29b299a73 and is marked using a green rectangle.

Write somewhere down the IDs of both source and destination virtual machines - you will need them later.

Check Status of the source virtual machine (in the screenshot, it is marked with an orange rectangle). If it is SHUTOFF, skip section Shutting down your virtual machine and proceed directly to section Disconnecting a volume.

If, however, the Status of the source virtual machine is ACTIVE, like on the screenshot above, proceed to section Shutting down your virtual machine.

General concerns about shutting down a virtual machine

The volume and its virtual machine are connected so if you abruptly cut out it out, some data on the volume may be lost. To be on the safe side, shut down the source virtual machine first.

There are two ways to shut down a virtual machine:

Using OpenStack commands

OpenStack will first request your virtual machine to shut down. If the virtual machine is unsuccessful at doing so, after a grace period, OpenStack will force it to power off.

Using operating system of the VM

On rare occasions, this forced powering off may lead to data loss so the alternative is using native commands of the operating system. The technical details, however, are out of scope of this article.

Shutting down the source virtual machine using OpenStack CLI

Skip this section if you decided to shut down your virtual machine using the functions of operating system installed on source virtual machine.

The OpenStack CLI command to shut down the VM is

openstack server stop b9f2017b-d8f2-420d-a0cb-36867228f17e

It goes without saying that you should replace b9f2017b-d8f2-420d-a0cb-36867228f17e with the ID of the source virtual machine.

The output of this command should be empty.

After that, list the servers, possibly multiple times, until your virtual machine has the following Status (on screenshot below marked using orange rectangle): SHUTOFF.

openstack server list
../_images/how-to-move-data-volume-cli-32_creodias.png

Disconnecting volume

To disconnect the volume, execute the openstack server remove volume command followed by the ID of the source virtual machine and the ID of the volume. Make sure to separate these values with spaces.

In this example, this command will be:

openstack server remove volume b9f2017b-d8f2-420d-a0cb-36867228f17e 851a3a86-d569-44e4-8c17-f3907af88500

If the operation was successful, the output should be empty. To verify, execute:

openstack volume list
../_images/how-to-move-data-volume-cli-13_creodias.png

Your volume should have the following Status (marked on screenshot above using red rectangle): available. Also, no value should be present in the Attached to column (this field was marked using green rectangle).

Attaching volume to the destination virtual machine

Execute the openstack server add volume –disable-delete-on-termination command followed by ID of the destination virtual machine and ID of the volume you want to attach. Remember to separate these values with spaces.

In this example, the command will be:

openstack server add volume --disable-delete-on-termination 97018102-1706-43e3-933b-60e29b299a73 851a3a86-d569-44e4-8c17-f3907af88500

If the operation was successful, you should get output similar to this:

../_images/how-to-move-data-volume-cli-14_creodias.png

To verify, execute the openstack volume list command once more:

../_images/how-to-move-data-volume-cli-15_creodias.png

The Status of the volume should now be in-use and the Attached to column should contain appropriate information regarding to which virtual machine your volume was attached.

What To Do Next

Now that volume has been connected to the destination virtual machine, you can allow or simplify access to it from that virtual machine. This might include:

  • assigning a drive letter to the volume (in case of Windows)

  • creating a mount point and adding the volume to /etc/fstab file (in case of Linux)

The volume can also be moved using the Horizon dashboard:

How to transfer volumes between domains and projects using Horizon dashboard on ESA HPC.