Re: Resync Every Sunday

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

 




On 01/07/2012 22:57, Jonathan Tripathy wrote:

On 01/07/2012 22:24, Larkin Lowrey wrote:
There was a fedora bug in the raid-check script would only queue an
array for check if the array_state was 'clean'. Unfortunately, when the
array is busy performing normal I/O its array_state is 'active'. So, any
arrays which were servicing I/O at the time raid-check was run would not
be checked.

It is quite possible that your CentOS version does not include the fix.

https://bugzilla.redhat.com/show_bug.cgi?id=679843

If it's fixed you should see something like:

# Only perform the checks on idle, healthy arrays, but delay
# actually writing the check field until the next loop so we
# don't switch currently idle arrays to active, which happens
# when two or more arrays are on the same physical disk
array_state=`cat /sys/block/$dev/md/array_state`
if [ "$array_state" != "clean" -a "$array_state" != "active" ]; then
     continue
fi

The fix, iirc, was simply the inclusion of '-a "$array_state" !=
"active"' in the 'if' statement above.

--Larkin
Hi Larkin,

This sounds like exactly what I'm experiencing.

Is this 'if' statement supposed to be in the raid-check script? I don't have any if statement in my raid-check script

Thanks

Here is a small part of my 99-raid-check script:

for dev in $active_list; do
    echo $SKIP_DEVS | grep -w $dev >/dev/null 2>&1 && continue
    if [ -f /sys/block/$dev/md/sync_action ]; then
        # Only perform the checks on idle, healthy arrays, but delay
        # actually writing the check field until the next loop so we
        # don't switch currently idle arrays to active, which happens
        # when two or more arrays are on the same physical disk
        array_state=`cat /sys/block/$dev/md/array_state`
        sync_action=`cat /sys/block/$dev/md/sync_action`
        if [ "$array_state" = clean -a "$sync_action" = idle ]; then
            ck=""
            echo $REPAIR_DEVS | grep -w $dev >/dev/null 2>&1 && ck="repair"
            echo $CHECK_DEVS | grep -w $dev >/dev/null 2>&1 && ck="check"
            [ -z "$ck" ] && ck=$CHECK
            dev_list="$dev_list $dev"
            check[$devnum]=$ck
            let devnum++
            [ "$ck" = "check" ] && check_list="$check_list $dev"
        fi
    fi
done

So the bug hasn't been fixed in my version then?

Thanks
--
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