On 2024-11-08 at 23:48 Marcin Debowski wrote:
>> W Seagate'ach interpretacja wartości atrybutów SMART nie jest taka
>> oczywista. Np. chyba gdzieś kiedyś czytałem, że atrybut Seek Error
>> Rate ma 48 bitów, z czego pierwsze 16 to liczba błędów, a pozostałe
>> 32 to całkowita liczba operacji seek. […]
I tak właśnie jest -- odszukałem w międzyczasie, gdzie to widziałem:
https://t1.daumcdn.net/brunch/service/user/axm/file/zRYOdwPu3OMoKYmBOby1fEEQEbU.pdf
Wykorzystując te informacje, jeśli wpiszesz do /etc/smart_drivedb.h
taki rekord:
{ "Seagate BarraCuda 3.5",
"ST4000DM004-2CV104",
"",
"",
"-v 1,hex56,Raw_Read_Error_Rate "
"-v 7,hex48,Seek_Error_Rate "
"-v 195,hex56,Hardware_ECC_Recovered"
}
to dla tego modelu dysku smartctl będzie pokazywał raw values wymienionych
atrybutów heksadecymalnie. Np. gdyby w 100000000 operacji Seek było
zero, jeden lub dwa błędy, smartctl standardowo pokazałby raw values
100000000, 4394967296 lub 8689934592, a z powyższym wpisem 0x000005F5E100,
0x000105F5E100 lub 0x000205F5E100 (dzięki temu widać zmianę tylko na dwóch
najstarszych bajtach określających liczbę błędów).
Albo, jeśli zamienić linie z '-v' na:
"-v 1,raw24/raw32,Raw_Read_Error_Rate "
"-v 7,raw24/raw32:z543210,Seek_Error_Rate "
"-v 195,raw24/raw32,Hardware_ECC_Recovered"
może pokazywać jeszcze czytelniej, bo w formacie 'liczba błędów/liczba
operacji', czyli w przykładzie j.w. pokazałby 0/100000000, 1/100000000
lub 2/100000000.
|