Re: hung grow

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Curt,

Let me endorse Wol's prescription, with a few comments:

On 10/04/2017 05:08 PM, Anthony Youngman wrote:
> On 04/10/17 21:01, Curt wrote:

{ Side note: what possessed you to do a grow operation? }

>> I'll be doing a ddrescue on the drives tonight, but will wait till
>> Phil or someone chimes in with my next steps after I do that.

I haven't seen complete mdadm -E reports for all of these devices, nor
mdadm -D for the array itself.  Please do so now.  If you have any of
that from before the crash, please post that too.  Run mdadm -E on the
two earliest failed drives.

Post the uncut output inline here on the list, in plain text mode, with
line wrap disabled, please.

> If you've got enough to ddrescue all of those five original drives, then
> that's absolutely great.
> 
> Remember - if we can't get five original drives (or copies thereof) the
> array is toast.
>>
>> lol, chalk one more up for FML. "SCT Error Recovery Control command
>> not supported".  I'm guessing this is a real bad thing now?  I didn't
>> buy these drives or org set it up.
>>
> I'm not sure whether this is good news or bad. Actually, it *could* be
> great news for the rescue! It's bad news for raid though, if you don't
> deal with it up front - I guess that wasn't done ...

It is mixed news.  It is almost certainly the reason you've had drives
bumped out of your arrays.  I suspect these drives all report *PASSED*
from smartctl.  Which means that the drives really are good, just
suffering from ordinary uncorrected errors.

You'll certainly have to use the 180 second driver timeout work-around
to get through this crisis.

In the meantime, please run "smartctl -iA -l scterc" on each of your
drives, including the failed ones, and post the uncut output here.
{ Include the device name with each }

> Go and read the wiki - the "When Things Go Wrogn" section. That will
> hopefully help a lot and it explains the Error Recovery stuff (the
> timeout mismatch page). Fix that problem and your dodgy drives will
> probably dd without trouble at all.

Let me emphasize this.  The timeout mismatch problem is so prevalent and
your experience so common that I thought to myself "I bet this one is
timeout mismatch" when I read your first mail.

> Hopefully with all copied drives, but if you have to mix dd'd and
> original drives you're probably okay, you should now be able to assemble
> a working array with five drives by doing an

As already noted, you definitely need to use ddrescue on the third
drive that failed.  You may also need to ddrescue your four remaining
good drives if they also have "Pending Sector" counts.

> mdadm --assemble blah blah blah --update=revert-reshape
> 
> That will put you back to a "5 drives out of 7" working array. The
> problem with this is that it will be a degraded, linear array.

This is the correct next step, after all required ddrescues.

> I'm not sure whether a --display will list the failed drives - if it
> does you can now --remove them. So you'll now have a working, 7-drive
> array, with two drives missing.

This is the time to grab any backups you need of critical content.  Do
*not* write to the array at this point.  Get all your data off.

Then:

> Now --add in the two new drives. MAKE SURE you've read the section on
> timeout mismatch and dealt with it! The rebuild/recovery will ALMOST
> CERTAINLY FAIL if you don't! Also note that I am not sure about how
> those drives will display while rebuilding - they may well display as
> being spares during a rebuild.

The timeout mismatch fixes won't help your case.  You have no redundancy
left, so the kickout scenarios involved no longer apply.  They applied
when your first two drives were kicked out.  When timeouts are not
mismatched, MD raid *fixes* the occasional bad sector.

> Lastly, MAKE SURE you set up a regular scrub. There's a distinct
> possibility that this problem wouldn't have arisen (or would have been
> found quicker) if a scrub had been in place. And if you can set up a
> trigger that emails you the contents of /proc/mdstat every few days.
> It's far too easy to miss a failed drive if you don't have something
> shoving it in your face every few days.

If you have a timeout mismatch problem, one's array will die much sooner
with scrubs.  Because MD raid will fail to fix UREs, and it will find
them right away.

But again, get us the detailed reports, and we'll help make sure your
commands are correct.

Phil
--
To unsubscribe from this list: send the line "unsubscribe linux-raid" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux RAID Wiki]     [ATA RAID]     [Linux SCSI Target Infrastructure]     [Linux Block]     [Linux IDE]     [Linux SCSI]     [Linux Hams]     [Device Mapper]     [Device Mapper Cryptographics]     [Kernel]     [Linux Admin]     [Linux Net]     [GFS]     [RPM]     [git]     [Yosemite Forum]


  Powered by Linux