PARALLEL DATA LAB 

PDL Abstract

Coding Techniques for Handling Failures in Large Disk Arrays

Algorithmica, vol. 12, no. 3-4, June 1994, pp. 182-208.

L. Hellerstein, G.A. Gibson*, R.M. Karp, R.H. Katz, and D.A. Patterson

*School of Computer Science
Carnegie Mellon University
Pittsburgh, PA 15213

http://www.pdl.cmu.edu/

A crucial issue in the design of very large disk arrays is the protection of data against catastrophic disk failures. Although today single disks are highly reliable, when a disk array consists of 100 or 1000 disks, the probability that at least one disk will fail within a day or a week is high. In this paper, we address the problem of designing erasure-correcting binary linear codes that protect against the loss of data caused by disk failures in large disk arrays. We describe how such codes can be used to encode data in disk arrays, and give a simple method for data reconstruction. We discuss important reliability and performance constraints of these codes, and show how these constraints relate to properties of the parity check matrices of the codes. In so doing, we transform code design problems into combinatorial problems. Using this combinatorial framework, we present codes and prove they are optimal with respect to various reliability and performance constraints.

FULL PAPER: pdf / postscript