Testing out Azure Storage Mover

I recently noticed that Azure Storage Mover is now Generally Available. This is a service I’ve not used before, but migrations of Storage to Azure is something I am often involved with, so I was keen to test out this service, and explore the setup and usage with a test migration.  In this post I will run through an overview of Storage Mover, how it is setup, and also run through a simple test migration.


What is Azure Storage Mover?

Azure Storage Mover is a service that enables the migration of files and folders to Azure Storage, whilst minimizing downtime for your workload. Storage Mover can be used for a variety of migration requirements and scenarios.

 ✅ You can read more about Azure Storage Mover here within the Microsoft Docs site.

Azure Storage Mover is a Hybrid Cloud Service – so it comprises both a Cloud and Infrastructure component, and to use it we need to deploy both components.

Also, it is worth a reminder that the Cloud Migration basics for file and folder storage, is an essential read when migrating file workloads to Azure. You can read this guidance here.


What are the Supported Sources and Targets for a Move?

At the current time Azure Storage Mover enables the migration of NFS shares to an Azure Blob Container. For an overview of the supported sources and targets, see here: https://learn.microsoft.com/en-gb/azure/storage-mover/service-overview#supported-sources-and-targets.


Setup & Testing

To test out the Service, I will be using a simple setup, comprising of:

  • An Azure Subscription
  • AN Azure Storage Account with a Blob Container
  • An NFS Share hosted on a Windows Virtual Machine (within my Lab)
  • A Storage Mover Agent deployed within my Lab

To start testing – I will first browse to my NFS share, and show that there is some data within:

NFS Share - showing data within.
NFS Share – showing data within.

I also have an Azure Storage Account with a Blob Container setup – this is currently empty, and will be the target destination I use for the data above:

Storage Account setup with a Container called "migration01".
Storage Account setup with a Container called “migration01”.

Creating the Storage Mover

Next we need to deploy the Azure Storage Mover Resource – this is done from within the Azure Portal:

Storage Mover setup - using search
Storage Mover setup – using search

Click on “Create storage mover”:

Storage Mover setup - Creation
Storage Mover setup – Creation

We can then fill in a few basic details to begin:

Storage Mover setup - Basic details
Storage Mover setup – Basic details

There is also an option to add Monitoring to Storage Mover – which enables metrics and logs to be collected:

Storage Mover setup - Log Analytics
Storage Mover setup – Log Analytics

Once this is done we can move onto the “Review + create” pane, and then create the Resource. Once created, we can see our Storage Mover:

Storage Mover setup - Created Resource, ready for our agent.
Storage Mover setup – Created Resource, ready for our agent.

We can now move onto the Agent Deployment. The agent is how our Storage Mover Resource will be able to community with our on-premises storage shares and devices.

Agent Deployment

Storage Mover makes the Agent deployment a simple process – from the Storage Mover overview, click on “Register agent”, as shown below:

Registering our Mover Agent
Registering our Storage Mover Agent

You’ll then be prompted to download the Agent:

Registering our Mover Agent
Registering our Storage Mover Agent

The link shown above will take you to a Microsoft download page, that allows you to download the VHDX for the Agent VM. Once this has downloaded we need to deploy this within our environment. My Lab environment is using Hyper-V, so the process is simple. If you need guidance on deployment of the VHDX to Hyper-V, please see this guide here: https://learn.microsoft.com/en-gb/azure/storage-mover/agent-deploy?tabs=xdmshell.

At this point, it is also worth noting that the Storage Mover agent VM requires outbound unrestricted internet connectivity. There is also a table of CPU Cores and RAM recommendations that needs consideration, depending upon the scale of migration: https://learn.microsoft.com/en-gb/azure/storage-mover/agent-deploy?tabs=xdmshell#recommended-compute-and-memory-resources. A minimum of 20 GB of disk space is also required – with potentially more space for a large migration.

Once the VM is deployed, and has been booted, we can connect via SSH, using the default credentials of admin/admin, and we are prompted to update the password. Note, you can use Hyper-V to check the IP you need to connect to!

Connecting in via PuTTY
Connecting in via PuTTY

We can now start the process of Registering the agent. To do this, select “4” from the menu, which starts the Registration process. Once you select this option and press enter, you will be prompted to enter the following information:

  • Tenant ID
  • Subscription ID
  • Resource Group Name
  • Storage Mover Name
  • Whether Private Link is required
Configuration via PuTTY
Configuration via PuTTY

Once completed – you will see the following:

Agent configuration completed!
Agent configuration completed!

Our Agent is now Registered:

Agent online and ready for use!
Agent online and ready for use!

We can now setup our Storage Target within Storage Mover, before we move onto the Migration.

Adding our Storage Endpoints

We can now add our Storage Endpoints to Storage Mover, so that we have our source and destination endpoints configured. We will start with our target endpoint – to do this, visit your Storage Mover in the Portal, and click on “Storage endpoints”, then “Create endpoint”, and select “Create target endpoint”:

Creating a Target Endpoint
Creating a Target Endpoint

We are then prompted to fill in some details – as you can see I have selected my Subscription, Storage Account, and Container, and provided a description:

Target Endpoint details
Target Endpoint details

Once these details are added, click on “Create”. After a few moments, our endpoint will then be added:

Our Target Endpoint is added and ready for use
Our Target Endpoint is added and ready for use

Our Target endpoint is now added, and we can now move on to adding our Source endpoint. To do this, click on the “Create endpoint” drop down and select “Create source endpoint”:

Adding a Source Endpoint
Adding a Source Endpoint

This will bring up a window for us to add the details of our source NFS Share:

Adding our Source NFS Share details
Adding our Source NFS Share details

Once the details are added, we can click on “Create”, and our Source will be added:

Source endpoint added and ready to use
Source endpoint added and ready to use

We can now move onto the Migration!

Migration

Once our Agents, and Source and Target endpoints are setup, Migration is a straightforward process using Storage Mover. We next need to create a Project, and then a Job within this project – which we can do from the main Storage Mover window. To get started click on “create project”:

Create a Storage Mover project
Create a Storage Mover project

This will bring up the Project explorer window, where we need to click on “create project” again to start. We can then fill in basic details and click on “create”:

Creating our migration project
Creating our migration project

We can now create a job definition within this project:

Creating a Job definition
Creating a Job definition

We can now fill in the job definition details – there are a few screens for this, which are shown below:

Step 1 - Creating our migration job
Step 1 – Creating our migration job
Step 2 - Selecting endpoint source
Step 2 – Selecting endpoint source
Step 3 - Selecting target endpoint
Step 3 – Selecting target endpoint
Step 4 - Migration settings
Step 4 – Migration settings
Step 5 - Review
Step 5 – Review

Our job will now be setup – and we can review this from the Project explorer. Once we are happy with the details shown, we can click on “Start job”:

Start migration job
Start migration job

The job will then show as “Queued”, whilst the agent picks up the job:

Migration job queued
Migration job queued

Once the operation is completed, you will see the overview screen that details how the job went. Note I added a few more files to my share to increase the number of files/objects since I took the “source” screenshot at the start of this post.

Migration job completed
Migration job completed

We can now browse to our Storage Account and confirm that files are showing as expected. I can see the test files I added below:

Confirming Test migration files can be seen
Confirming Test migration files can be seen

This concludes my test migration. Obviously in a production scenario it’s likely to be significantly more data or shares, however this post hopefully demonstrates the simplicity with which migration can be done using Storage Mover – and in particular, how it can be used to manage a number of migration jobs across different sources and targets.

Post-Migration/Clean Up

When removing Storage Mover Resources it is important to note a few key aspects, particularly around decommissioning of the agent – see here for more details: https://learn.microsoft.com/en-us/azure/storage-mover/agent-deploy?tabs=xdmshell#decommissioning-an-agent.


Conclusion

As you can see, Storage Mover is a useful Resource that provides a streamlined and simple approach to migrating NFS Shares to Azure Storage. As this service continues to develop I’ll be keeping a close eye on how more storage sources can be migrated and transformed using this service! ✅

Skip to content