DMTCP: Transparent Checkpointing for Cluster Computations and the Desktop

DMTCP (Distributed MultiThreaded CheckPointing) is a transparent user-level checkpointing package for distributed applications. Checkpointing and restart is demonstrated for a wide range of over 20 well known applications, including MATLAB, Python, TightVNC, MPICH2, OpenMPI, and runCMS. RunCMS runs...

Full description

Bibliographic Details
Main Authors: Arya, Kapil (Author), Cooperman, Gene (Author), Ansel, Jason Andrew (Contributor)
Other Authors: Massachusetts Institute of Technology. Computer Science and Artificial Intelligence Laboratory (Contributor)
Format: Article
Language:English
Published: Institute of Electrical and Electronics Engineers, 2010-10-05T20:52:57Z.
Subjects:
Online Access:Get fulltext
LEADER 02568 am a22002173u 4500
001 58883
042 |a dc 
100 1 0 |a Arya, Kapil  |e author 
100 1 0 |a Massachusetts Institute of Technology. Computer Science and Artificial Intelligence Laboratory  |e contributor 
100 1 0 |a Ansel, Jason Andrew  |e contributor 
100 1 0 |a Ansel, Jason Andrew  |e contributor 
700 1 0 |a Cooperman, Gene  |e author 
700 1 0 |a Ansel, Jason Andrew  |e author 
245 0 0 |a DMTCP: Transparent Checkpointing for Cluster Computations and the Desktop 
260 |b Institute of Electrical and Electronics Engineers,   |c 2010-10-05T20:52:57Z. 
856 |z Get fulltext  |u http://hdl.handle.net/1721.1/58883 
520 |a DMTCP (Distributed MultiThreaded CheckPointing) is a transparent user-level checkpointing package for distributed applications. Checkpointing and restart is demonstrated for a wide range of over 20 well known applications, including MATLAB, Python, TightVNC, MPICH2, OpenMPI, and runCMS. RunCMS runs as a 680 MB image in memory that includes 540 dynamic libraries, and is used for the CMS experiment of the Large Hadron Collider at CERN. DMTCP transparently checkpoints general cluster computations consisting of many nodes, processes, and threads; as well as typical desktop applications. On 128 distributed cores (32 nodes), checkpoint and restart times are typically 2 seconds, with negligible run-time overhead. Typical checkpoint times are reduced to 0.2 seconds when using forked checkpointing. Experimental results show that checkpoint time remains nearly constant as the number of nodes increases on a medium-size cluster. DMTCP automatically accounts for fork, exec, ssh, mutexes/semaphores, TCP/IP sockets, UNIX domain sockets, pipes, ptys (pseudo-terminals), terminal modes, ownership of controlling terminals, signal handlers, open file descriptors, shared open file descriptors, I/O (including the readline library), shared memory (via mmap), parent-child process relationships, pid virtualization, and other operating system artifacts. By emphasizing an unprivileged, user-space approach, compatibility is maintained across Linux kernels from 2.6.9 through the current 2.6.28. Since DMTCP is unprivileged and does not require special kernel modules or kernel patches, DMTCP can be incorporated and distributed as a checkpoint-restart module within some larger package. 
520 |a National Science Foundation (U.S.) (Grant CNS-06-19616) 
546 |a en_US 
655 7 |a Article 
773 |t IEEE International Symposium on Parallel & Distributed Processing, 2009. IPDPS 2009