Efficient Large-Scale Language Model Training on GPU Clusters Using Megatron-LM
- Deepak Narayanan ,
- Mohammad Shoeybi ,
- Jared Casper ,
- Patrick LeGresley ,
- Mostofa Patwary ,
- Vijay Anand Korthikanti ,
- Dmitri Vainbrand ,
- Prethvi Kashinkunti ,
- Julie Bernauer ,
- Bryan Catanzaro ,
- Amar Phanishayee ,
- Matei Zaharia
International Conference for High Performance Computing, Networking, Storage and Analysis (SC 2021) |
Best Student Paper
下载 BibTexLarge language models have led to state-of-the-art accuracies across a range of tasks. However, training these models efficiently is challenging for two reasons: a) GPU memory capacity is limited, making it impossible to fit large models on even a multi-GPU server, and b) the number of compute operations required to train these models can result in unrealistically long training times. Consequently, new methods of model parallelism such as tensor and pipeline parallelism have been proposed. Unfortunately, naïve usage of these methods leads to fundamental scaling issues at thousands of GPUs, e.g., due to expensive cross-node communication or devices spending significant time waiting on other devices to make progress.
In this paper, we show how different types of parallelism methods (tensor, pipeline, and data parallelism) can be composed to scale to thousands of GPUs and models with trillions of parameters. We survey techniques for pipeline parallelism and propose a novel interleaved pipeline parallelism schedule that can improve throughput by 10+% with memory footprint comparable to existing approaches. We quantitatively study the trade-offs between tensor, pipeline, and data parallelism, and provide intuition as to how to configure distributed training of a large model. Our approach allows us to perform training iterations on a model with 1 trillion parameters at 502 petaFLOP/s on 3072 GPUs with achieved per-GPU throughput of 52% of theoretical peak. Our code is open sourced at https://github.com/nvidia/megatron-lm (opens in new tab).