On 05/10/2012 11:26 AM, Marcus Sorensen wrote: > On Thu, May 10, 2012 at 7:51 AM, Phil Turmel <philip@xxxxxxxxxx> wrote: [trim /] >> Here is where Marcus and I part ways. A very common report I see on >> this mailing list is people who have lost arrays where the drives all >> appear to be healthy. Given the large size of today's hard drives, >> even healthy drives will occasionally have an unrecoverable read error. >> >> When this happens in a raid array with a desktop drive without SCTERC, >> the driver times out and reports an error to MD. MD proceeds to >> reconstruct the missing data and tries to write it back to the bad >> sector. However, that drive is still trying to read the bad sector and >> ignores the controller. The write is immediately rejected. BOOM! The >> *write* error ejects that member from the array. And you are now >> degraded. >> >> If you don't notice the degraded array right away, you probably won't >> notice until a URE on another drive pops up. Once that happens, you >> can't complete a resync to revive the array. >> >> Running a "check" or "repair" on an array without TLER will have the >> opposite of the intended effect: any URE will kick a drive out instead >> of fixing it. >> >> In the same scenario with an enterprise drive, or a drive with SCTERC >> turned on, the drive read times out before the controller driver, the >> controller never resets the link to the drive, and the followup write >> succeeds. (The sector is either successfully corrected in place, or >> it is relocated by the drive.) No BOOM. >> > > Agreed. In the past there has been some debate about this. I think it > comes down to your use case, the data involved and what you expect. > TLER/ERC can generally make your array more durable to minor hiccups, > and is likely preferred if you can stomach the cost, at the potential > risk that I described. If the failure is a simple one-off read > failure, then Phil's scenario is very likely. If the drive is really > going bad (say hitting max_read_errors), then the disk won't try very > hard to recover your data, at which point you have to hope the other > drive doesn't have even a minor read error when rebuilding, because it > also will not try very hard. In the end it's up to you what behavior > you want. Well, I approach this from the assumption that the normal condition of a production RAID array is *non-degraded*. You don't want isolated read errors to hold up your application when the data can be quickly reconstructed from the redundancy. And you certainly don't want transient errors to kick drives out of the array. Coordinating the drive and the controller timeouts is the *only* way to avoid the URE kickout scenario. Changing TLER/ERC when an array becomes degraded for a real hardware failure is a useful idea. I think I'll look at scripting that. > Here are a few odd things to consider, if you're worried about this topic: > > * Using smartctl to increase the ERC timeout on enterprise SATA > drives, say to 25 seconds, for use with md. I have no idea if this > will cause the drive to actually try different methods of recovery, > but it could be a good middle ground. For a healthy array, I think this is counter-productive, as you are holding up your applications. Any sector that is marginal and needs that much time to recover really ought to be re-written anyways. > * increasing max_read_errors in an attempt to keep a TLER/ERC disk in > the loop longer. The only reason to do this would be if you were > proactive in monitoring said errors and could add in more redundancy > before pulling the failing drive, thus increasing your chances that > the rebuild succeeds, having more *mostly* good copies. > > * Increasing the SCSI timeout on your desktop drives to 60 seconds or > more, giving the drive a chance to succeed in deep recovery. This may > cause IO to block for awhile, so again it depends on your usage > scenario. I can understand using all available means to resync/rebuild a degraded array, but I can't see leaving those settings on a healthy array. > * frequent array checks - perhaps in combination with the above, can > increase the likelihood that you find errors in a timely manner and > increase the chances that the rebuild will succeed if you've only got > one good copy left. Frequent array checks are not optional, if you want flush out any UREs in the making, and maximize your odds of successfully rebuilding after a drive replacement. If you are running RAID6 or a triple mirror, with frequent checks, you are very safe. [...] >> Neither Seagate nor Western Digital offer any desktop drive with any >> form of time-limited error recovery. Seagate and WD were my "go to" >> brands for RAID. I am now buying Hitachi, as they haven't (yet) >> followed their peers. The "I" in RAID stands for "inexpensive", >> after all. > > I keep hearing that, and I was always under the impression that the > "I" stood for "Independent", as you can do RAID with any independent > disk, cheap or expensive. Seems it was changed mid-90's. I suppose > both are accepted, but perhaps the one we use says something about our > level of seniority :-) Hmmm. I hadn't noticed the change to "independent". Can't allow any premium technology to be inexpensive, can we? And yes, there's grey in my beard. 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