tf.data service: A Case for Disaggregating ML Input Data Processing

Andrew Audibert,Yang Chen,Dan Graur,Ana Klimovic,Jiri Simsa,Chandramohan A. Thekkath
DOI: https://doi.org/10.1145/3620678.3624666
2024-01-02
Abstract:Machine learning (ML) computations commonly execute on expensive specialized hardware, such as GPUs and TPUs, which provide high FLOPs and performance-per-watt. For cost efficiency, it is essential to keep these accelerators highly utilized. This requires preprocessing input data at the rate at which the accelerators can ingest and perform ML computations on the data. To avoid data stalls, the host CPU and RAM required for input data processing per accelerator core used for ML computations varies across jobs. Hence, the traditional approach of processing input data on ML accelerator hosts with a fixed hardware ratio leads to either under-utilizing the accelerators or the host CPU and RAM. In this paper, we address these concerns by building a disaggregated ML data processing system. We present <a class="link-external link-http" href="http://tf.data" rel="external noopener nofollow">this http URL</a> service, an open-source disaggregated input data processing service built on top of <a class="link-external link-http" href="http://tf.data" rel="external noopener nofollow">this http URL</a> in TensorFlow. We show that disaggregating data preprocessing has three key advantages for large-scale ML training jobs. First, the service can horizontally scale-out to right-size CPU/RAM host resources for data processing in each job, saving 32x training time and 26x cost, on average. Second, the service can share ephemeral preprocessed data results across jobs, to optimize CPU usage and reduce redundant computations. Finally, the service supports coordinated reads, a technique that avoids stragglers due to different input sizes in distributed training, reducing training time by 2.2x, on average. Our design is inspired by lessons learned from deploying <a class="link-external link-http" href="http://tf.data" rel="external noopener nofollow">this http URL</a> service in production, including relaxing data visitation guarantees without impacting model accuracy.
Machine Learning,Distributed, Parallel, and Cluster Computing
What problem does this paper attempt to address?