Skip to main content

Azure Data Lake and Replication mechanism cross Azure Regions

Context
Let’s imagine that we are working in an automotive company that collects telemetric data from their cars. A part of this data needs to be processed, stored and managed.
To be able to store data now and use it later on in time, you decided to go with Azure Data Lake, that is not limited on how much data you can store and allows you to plug any kind of processing system.
Requirements
After the architecture audit, because of legal constraints you are required to have a resiliency policy for disaster recovery. Even if in the same Azure Region there are 3 copies of data that are generated by Azure Data Lake, the legal constraints require you to have a resiliency policy.
Problem
Azure Data Lake makes 3 copies of data in the same Azure Region, but there is no support to replicated or backup content in a different Azure Region. You will need to define you own mechanism for this.

Available Solutions
We could fine many ways of doing this. There are 2-3 mechanism to do replication of Azure Data Lake cross region that is cost efficient and also not too complex from implementation point of view.
Azure Data Factory
One of the basic features of Azure Data Factory is support for copy activities. This is a generic service that allows us to move data from different types of storages. From binary content point of view, the current copy activities supported by Azure Data Factory offers us speeds up to 1 GBps for Azure Blob Storage and Azure Data Lake.
AdlCopy
This command can be used to move data from one Azure Data Lake to another. The command can be used with success as long as we integrate it in Azure Automation. This is required, because the command cannot run by its own. Azure Automation is the shell from where we run the command.

Downside of this solutions
This solution works well for small amount of data and when we don’t care about the deltas. If we can identify deltas by our self or we don’t care about it and we want to replicate everything than the previous two solutions are perfect.
If the process of delta identifications is too complex that we should go with Distcp command

Distcp
This can be used in combination with HDInsight to copy content from one storage to another. In comparison with the previous ones, it enables us to copy only the delta. Beside this, this command runs on top of a HDInsight (Hadoop) cluster, allowing it to scale inside the cluster based on how much traffic needs to be moved.

What’s suite our need?
Telemetric data collected from cars are grouped together per car and day and never updated. This means that we can identify easily what files need to be moved. Each car has a virtual folder with his own telemetric data. A new file is created each day. When a new car is sold, a new virtual folder is created.

This allows us to identify easily what files needs to be replicated and we don’t need to care about deltas, because we run the replication job only one time per day.
Taking this into account, Azure Data Factory is a good candidate.

Conclusion
As can see, there are multiple ways to do replication between different instances of Azure Data Factory. Even if Distcp is the best one, you need to take into account that you need to spin HDInsight clusters, that are more expensive that AdlCopy or Azure Data Factory.
When you handle storages where content is updated or copies rarely, then a solution based on Distcp might be too expensive and complex.

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...

Cloud Myths: Cloud is Cheaper (Pill 1 of 5 / Cloud Pills)

Cloud Myths: Cloud is Cheaper (Pill 1 of 5 / Cloud Pills) The idea that moving to the cloud reduces the costs is a common misconception. The cloud infrastructure provides flexibility, scalability, and better CAPEX, but it does not guarantee lower costs without proper optimisation and management of the cloud services and infrastructure. Idle and unused resources, overprovisioning, oversize databases, and unnecessary data transfer can increase running costs. The regional pricing mode, multi-cloud complexity, and cost variety add extra complexity to the cost function. Cloud adoption without a cost governance strategy can result in unexpected expenses. Improper usage, combined with a pay-as-you-go model, can result in a nightmare for business stakeholders who cannot track and manage the monthly costs. Cloud-native services such as AI services, managed databases, and analytics platforms are powerful, provide out-of-the-shelve capabilities, and increase business agility and innovation. H...