Hydra: a federated resource manager for data-center scale analytics
- Carlo Curino ,
- Subramaniam Venkatraman Krishnan ,
- Konstantinos Karanasos ,
- Sriram Rao ,
- Giovanni M. Fumarola ,
- Botong Huang ,
- Kishore Chaliparambil ,
- Arun Suresh ,
- Young Chen ,
- Solom Heddaya ,
- Roni Burd ,
- Sarvesh Sakalanaga ,
- Chris Douglas ,
- Bill Ramsey ,
- Raghu Ramakrishnan
Symposium on Networked Systems Design and Implementation (NSDI) |
Published by USENIX
Microsoft’s internal data lake processes exabytes of data over millions of cores daily on behalf of thousands of tenants. Scheduling this workload requires 10x to 100x more decisions per second than existing, general-purpose resource management frameworks are known to handle. In 2013, we were faced with a growing demand for workload diversity and richer sharing policies that our legacy system could not meet. In this paper, we present Hydra, the resource management infrastructure we built to meet these requirements.
Hydra leverages a federated architecture, in which a cluster is comprised of multiple, loosely coordinating subclusters. This allows us to scale by delegating placement of tasks on machines to each sub-cluster, while centrally coordinating only to ensure that tenants receive the right share of resources. To adapt to changing workload and cluster conditions promptly, Hydra’s design features a control plane that can push scheduling policies across tens of thousands of nodes within seconds. This feature combined with the federated design allows for great agility in developing, evaluating, and rolling out new system behaviors.
We built Hydra by leveraging, extending, and contributing our code to Apache Hadoop YARN. Hydra is currently the primary big-data resource manager at Microsoft. Over the last few years, Hydra has scheduled nearly one trillion tasks that manipulated close to a Zettabyte of production data.