Migrate on-premises Apache Hadoop clusters to Azure HDInsight - architecture best practices
This article gives recommendations for the architecture of Azure HDInsight systems. It's part of a series that provides best practices to assist with migrating on-premises Apache Hadoop systems to Azure HDInsight.
Use multiple workload-optimized clusters
Many on-premises Apache Hadoop deployments consist of a single large cluster that supports many workloads. This single cluster can be complex and may require compromises to the individual services to make everything work together. Migrating on-premises Hadoop clusters to Azure HDInsight requires a change in approach.
Azure HDInsight clusters are designed for a specific type of compute usage. Because storage can be shared across multiple clusters, it is possible to create multiple workload-optimized compute clusters to meet the needs of different jobs. Each cluster type has the optimal configuration for that specific workload. The following table lists the supported cluster types in HDInsight and the corresponding workloads.
|Workload||HDInsight Cluster type|
|Batch processing (ETL / ELT)||Hadoop, Spark|
|Data warehousing||Hadoop, Spark, Interactive Query|
|IoT / Streaming||Kafka, Storm, Spark|
|NoSQL Transactional processing||HBase|
|Interactive and Faster queries with in-memory caching||Interactive Query|
|Data Science||ML Services, Spark|
The following table shows the different methods that can be used to create an HDInsight cluster.
|Tool||Browser based||Command Line||REST API||SDK|
|Azure Data Factory||X||X||X||X|
|Azure CLI (ver 1.0)||X|
|Azure Resource Manager templates||X|
For more information, see the article Cluster types in HDInsight.
Use transient on-demand clusters
HDInsight clusters may go unused for long periods of time. To help save on resource costs, HDInsight supports on-demand transient clusters, which can be deleted once the workload has been successfully completed.
When you delete a cluster, the associated storage account and external metadata are not removed. The cluster can later be re-created using the same storage accounts and meta-stores.
Azure Data Factory can be used to schedule creation of on-demand HDInsight clusters. For more information, see the article Create on-demand Apache Hadoop clusters in HDInsight using Azure Data Factory.
Decouple storage from compute
Typical on-premises Hadoop deployments use the same set of machines for data storage and data processing. Because they are colocated, compute and storage must be scaled together.
On HDInsight clusters, storage does not need to be colocated with compute and can either be in Azure storage, Azure Data Lake Storage or both. Decoupling storage from compute has the following benefits:
- Data sharing across clusters.
- Use of transient clusters since the data isn't dependent on cluster.
- Reduced storage cost.
- Scaling storage and compute separately.
- Data replication across regions.
Compute clusters are created close to storage account resources in an Azure region to mitigate performance cost of separating compute and storage. High-speed networks make it efficient for the compute nodes to access the data inside Azure storage.
Use external metadata stores
There are two main metastores that work with HDInsight clusters: Apache Hive and Apache Oozie. The Hive metastore is the central schema repository that can be used by data processing engines including Hadoop, Spark, LLAP, Presto, and Apache Pig. The Oozie metastore stores details about scheduling and the status of in progress and completed Hadoop jobs.
HDInsight uses Azure SQL Database for Hive and Oozie metastores. There are two ways to set up a metastore in HDInsight clusters:
- No additional cost.
- Metastore is deleted when the cluster is deleted.
- Metastore can't be shared among different clusters.
- Uses basic Azure SQL DB, which has a five DTU limit.
Custom external metastore
- Specify an external Azure SQL Database as the metastore.
- Clusters can be created and deleted without losing metadata including Hive schema Oozie job details.
- Single metastore db can be shared with different types of clusters.
- Metastore can be scaled up as needed.
- For more information, see Use external metadata stores in Azure HDInsight.
Best practices for Hive Metastore
Some HDInsight Hive metastore best practices are as follows:
- Use a custom external metastore to separate compute resources and metadata.
- Start with an S2 tier Azure SQL instance, which provides 50 DTU and 250 GB of storage. If you see a bottleneck, you can scale the database up.
- Don't share the metastore created for one HDInsight cluster version with clusters of a different version. Different Hive versions use different schemas. For example, a metastore can't be shared with both Hive 1.2 and Hive 2.1 clusters.
- Back up the custom metastore periodically.
- Keep the metastore and HDInsight cluster in the same region.
- Monitor the metastore for performance and availability using Azure SQL Database Monitoring tools, like Azure portal or Azure Monitor logs.
- Execute the ANALYZE TABLE command as required to generate statistics for tables and columns. For example,
ANALYZE TABLE [table_name] COMPUTE STATISTICS.
Best practices for different workloads
- Consider using LLAP cluster for interactive Hive queries with improved response time LLAP is a new feature in Hive 2.0 that allows in-memory caching of queries. LLAP makes Hive queries much faster, up to 26x faster than Hive 1.x in some cases.
- Consider using Spark jobs in place of Hive jobs.
- Consider replacing impala-based queries with LLAP queries.
- Consider replacing MapReduce jobs with Spark jobs.
- Consider replacing low-latency Spark batch jobs using Spark Structured Streaming jobs.
- Consider using Azure Data Factory (ADF) 2.0 for data orchestration.
- Consider Ambari for Cluster Management.
- Change data storage from on-premises HDFS to WASB or ADLS or ADFS for processing scripts.
- Consider using Ranger RBAC on Hive tables and auditing.
- Consider using CosmosDB in place of MongoDB or Cassandra.
Read the next article in this series: