Hiding Checkpoint Overhead in HPC Applications with a Semi-Blocking Algorithm
IEEE International Conference on Cluster Computing (Cluster) 2012
Publication Type: Paper
Repository URL:
Abstract
The HPC community has seen a steady increase in the number of components in every generation of super- computers. Assembling a large number of components into a single cluster makes a machine more powerful, but also much more prone to failures. Therefore, fault tolerance has become a major concern in HPC. To deal with node crashes in large systems, checkpoint/restart is by far the preferred method. A typical way to implement checkpoints is by using a blocking algorithm, which suspends the execution of the application while the checkpoint is safely stored. One limitation of the blocking algorithm is that it saturates the network bandwidth at the time of checkpoint. This problem will become even more critical because the projected network bandwidth increase will not match the increase in memory per node. The checkpoint of a node will have to travel across a shrinking channel. To alleviate this problem, we have developed a semi-blocking checkpoint algorithm that overlaps execution of the application with transmission of checkpoints. Our implementation decomposes a checkpoint into small messages that are interleaved with application messages. The experimental results show a dramatic reduction in the checkpoint overhead for various applications. We present a model for our approach and use this model to compute the benefit of the semi-blocking algorithm for different failure rates predicted at Exascale. We estimate our method can reduce between 6-22% the total execution time of an iterative scientific application.
People
Research Areas