On 5/20/2021 3:48 PM, Nix wrote:
On 19 May 2021, Leslie Rhorer spake thusly:
That's a little bit of an overstatement, depending on what you
mean by "reasonably confident". Swapped drives should not ordinarily
cause an issue, especially with RAID 4 or 5. The parity is, after all,
numerically unique. Admin changes to the array should be similarly
fully established provided the rebuild completed properly. I don't
think the parity algorythms have changed over time in mdadm, either.
All sorts of creation-time things have changed over time: default chunk
sizes, drive ordering (particularly but not only for RAID10), data
offset, etc etc etc.
Which is why I explicitly specified those parameters (other than the
data offset) in the examp0le commands I listed. There is a build of
mdadm out there that allows one to specify the offset, as well.
The list is really rather long and the number of
possible combinations astronomical. (Sure, it's less astronomical if you
It's not astronomical, but in terms of just guessing it is indeed
rather large.
know what version of mdadm you made the array with in the first place,
but hardly anyone who hasn't already been bitten tracks that, and if
they do they probably recorded all the other relevant state too by
preserving --examine output, so no guesswork is needed.)
Which he did. This limits the field substantially.
Had they done so, mdadm would not be able to assemble arrays from
previous versions regardless of whether the superblock was intact.
Naah. Most of this stuff is recorded *in* the superblock, so mdadm can
assemble without difficulty or assistance:
Point taken. The OP's downfall will be if the superblocks were fiddled
substantially after he saved them. If not, he should be golden.
it doesn't do it by picking
defaults from inside mdadm's source code! *Those* defaults only apply at
array creation time.
Yes, of course.
But when recreating an array over the top of a
vanished one with the same parameters, you have to *remember* those
parameters...
Unless, of course, the defaults in the build match up with those used
in the last organization of the array. Fingers crossed, as it were.