On Wed Feb 23, 2011 at 11:20:34AM -0500, Iordan Iordanov wrote: > Hi guys, > > I just wanted to make sure that the behaviour I observed is as expected. > With kernel 2.6.35.11, under Debian Lenny, I created a RAID5 array with > 5 drives, partitioned it, formatted a partition with ext3 and mounted > it. Then, I put some load onto the filesystem with: > > dd if=/dev/urandom of=/mnt/testfile > > The array started initializing. At that point, I needed to fail and > replace a drive for some unrelated testing, so I did that with: > > mdadm /dev/md0 -f /dev/sdc > > The result was a broken filesystem which was remounted read-only, and a > bunch of errors in dmesg. Theoretically, one would imagine that failing > a drive on a RAID5 even during initialization should render the array > without redundancy but workable. Am I wrong? Is there something special > about the initialization stage of RAID5 that makes drive failure fatal > during the initialization? If not, then I have a bug to report and I'll > try to reproduce it for you. > The array is created in a degraded state, then recovered onto the final disk. Pulling any disk bar the final one will results in a broken array and lost data, until this recovery is completed. > If initialisation is special, does that mean that when creating RAID5, > it is advisable to *wait* until the array has fully initialized before > using it, otherwise one risks losing any data that was put onto the > array during the initialization phase if a drive fails at that point? > That depends. It's advisable not to use it for critical, non-backed up data (the same as it is during a recovery following a drive failure). The alternative is to wait until the array is fully initialised before making it available to the user (which could take a considerable amount of time) or manually zeroing all the drives and then creating the array using --assume-clean (in which case the zeroing means the parity data is correct by default). Some of the features on Neil's current roadmap should allow for "lazy initialisation" where the recovery data is added only as the drive is written to, which should mean the array is available immediately but still retains full recoverability. Cheers, Robin -- ___ ( ' } | Robin Hill <robin@xxxxxxxxxxxxxxx> | / / ) | Little Jim says .... | // !! | "He fallen in de water !!" |
Attachment:
pgpRVNwICXdyo.pgp
Description: PGP signature