Skip to main content

Initial migration cost assessment when you need to change the cloud provider

It is not uncommon to migrate a cloud solution from one cloud provider to another. The business assessment that is done before decided to do such a migration with a direct impact on the financial and business areas is crucial. 
Unfortunately, this kind of decision is taken in most of the cases based on personal preferences or in fast response to an incident (e.g. slow response of an open ticket).

The migration analyzes of the impact from business, technical, financial, and long term vision is complex. In this post, I present an initial exercise that can be done to measure the impact on such a migration that offers a financial score.

There are 8 main factors that impact the migration cost:
(1) Cloud Services Integration: The impact and effort to update the application layer to be able to communicate with the SDK and API of the new cloud provider (e.g. migration from AWS S2 to Azure Blob Storage).
(2) Component rewrite: Sometimes there are no 1:1 match cross-cloud services. It means that to be able to support the same functionality you will need to rewrite or change the current implementation (e.g. SSIS package cannot run as-is inside AWS and you need to rewrite it for AWS Glue). 
Learning curve / Peope skills: The current team might not have knoeledge related to the new cloud provider, so you will need to suport the cost of learning or adding/rotateing the team members. When you get new people in the team, you lose business knoledge.  
(3) Cloud running cost: The running cost of the current cloud provider until the end of the current version life-cycle compared in comparison with the cost of the new cloud provider.
Resource reservation: If you already have done a resource reservation for 1 or 3 years, you cannot step back so easily. You will have some costs generated by it.
(4) Management and Operation cost: The cost of M&A on both cloud providers, taking into account that you might have extra costs generated by the learning curve or you need to hire new people. Additional to this the set of tools that you use might change also.
(5) IaaC and Automation: The cost of creating cloud resources in the new cloud provider they are not to be ignored. Even if you used Terraform, things will not go so smoothly as you expect. 
(6) Testing and Quality Insurance: The system will need to be retested. Depending on how you have done the initial testing the effort might be higher or lower.
(7) Cloud Integration: Refers to the effort of integration of the new cloud provider with your current infrastructure (VPN, security, and so on). In most cases, we can assume that is low because you are not the first system that runs in the new cloud provider.
(8) Re-certification: By changing the cloud provider you need to recertify the solution to be compliant with specific compliance (e.g. HIPAA, PCI DSS).

From past experience, I can tell you that (1) Cloud Service Integration and (5) IaaC and Automation are the most expensive ones. Even with Terraform, changing the cloud platform is a pain, because in most of cases cross-cloud compatibility was not in the mind of the team. If you need to do (2) Component rewrite than you might have budget issues. 

Now, let's take a look at a real-life example, to understand better the real impact on such a 'simple' migration.
 Factor  Impact  Cost       Comments
Cloud Services Integration Storage, No-SQL$15000 
Component rewrite No impact.            $0 
Cloud running cost (current provider) -     $48000/year         
 Cloud running cost (new provider)  $30000/year    Special discounts from the cloud provider.
Management and Operation cost (current provider) - $12000/year 
 Management and Operation cost (new provider) - $12000/year
$2000 (understand the solution)
 The company already has people the competency on the new cloud provider
IaaC and Automation Terraform $20000         Update the configuration and setup for the new cloud provider and environment recreation
Testing and Quality Insurance  $14000    Running the automated test, and manually run the integration ones. Including updating the automated tests to look in new logs location.
Cloud Integration  $0     Already used.
Re-certification  $0 No certifications required

The lifecycle of the application is 4 years, and the system has been running for 1 year already. If we do the calculation it means that:
  • The total cost of staying on the current cloud provider for the next 3 years is $180000
  • The total cost of migration to another cloud provider and running the solution for 3 years is $177000
As you can see the grand total difference between staying on the same cloud provider or doing a migration is under $4000 in 3 years. If we would already have a resource reservation that was paid upfront, the difference could be negative.

It is interesting to take a look at the initial implementation cost that was around $150000 with the migration cost $51000. The migration cost is around 30% of the initial implementation cost. 

As we can see even if the running cost between the two cloud providers is around 35% less, the cost of migration to another cloud provider reduces drastically the cost benefits. This is why when you decide to migrate from one cloud provider to another, the main driver shall not be the cloud services cost. 
In most cases, the migration effort cost is 30% to 40% of your initial implementation cost.  

Comments

Popular posts from this blog

Windows Docker Containers can make WIN32 API calls, use COM and ASP.NET WebForms

After the last post , I received two interesting questions related to Docker and Windows. People were interested if we do Win32 API calls from a Docker container and if there is support for COM. WIN32 Support To test calls to WIN32 API, let’s try to populate SYSTEM_INFO class. [StructLayout(LayoutKind.Sequential)] public struct SYSTEM_INFO { public uint dwOemId; public uint dwPageSize; public uint lpMinimumApplicationAddress; public uint lpMaximumApplicationAddress; public uint dwActiveProcessorMask; public uint dwNumberOfProcessors; public uint dwProcessorType; public uint dwAllocationGranularity; public uint dwProcessorLevel; public uint dwProcessorRevision; } ... [DllImport("kernel32")] static extern void GetSystemInfo(ref SYSTEM_INFO pSI); ... SYSTEM_INFO pSI = new SYSTEM_INFO(...

How to audit an Azure Cosmos DB

In this post, we will talk about how we can audit an Azure Cosmos DB database. Before jumping into the problem let us define the business requirement: As an Administrator I want to be able to audit all changes that were done to specific collection inside my Azure Cosmos DB. The requirement is simple, but can be a little tricky to implement fully. First of all when you are using Azure Cosmos DB or any other storage solution there are 99% odds that you’ll have more than one system that writes data to it. This means that you have or not have control on the systems that are doing any create/update/delete operations. Solution 1: Diagnostic Logs Cosmos DB allows us activate diagnostics logs and stream the output a storage account for achieving to other systems like Event Hub or Log Analytics. This would allow us to have information related to who, when, what, response code and how the access operation to our Cosmos DB was done. Beside this there is a field that specifies what was th...

ADO.NET provider with invariant name 'System.Data.SqlClient' could not be loaded

Today blog post will be started with the following error when running DB tests on the CI machine: threw exception: System.InvalidOperationException: The Entity Framework provider type 'System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer' registered in the application config file for the ADO.NET provider with invariant name 'System.Data.SqlClient' could not be loaded. Make sure that the assembly-qualified name is used and that the assembly is available to the running application. See http://go.microsoft.com/fwlink/?LinkId=260882 for more information. at System.Data.Entity.Infrastructure.DependencyResolution.ProviderServicesFactory.GetInstance(String providerTypeName, String providerInvariantName) This error happened only on the Continuous Integration machine. On the devs machines, everything has fine. The classic problem – on my machine it’s working. The CI has the following configuration: TeamCity .NET 4.51 EF 6.0.2 VS2013 It see...