Что делать с поврежденным пулом ZFS
Был запущен тестовый экземпляр NAS с использованием ZFS, как упоминалось в разделе "Восстановление сервера Ubuntu с использованием ZFS RAIDZ для данных".
На этой неделе один из моих дисков умер. Не должно ли быть проблемой, не так ли (преимущества RAID - это устойчивость и производительность)?
За исключением того, что мой пул ZFS был поврежден, как в:
andy@ubuntu:~$ sudo zpool status -v
pool: tank
state: UNAVAIL
status: One or more devices could not be used because the label is missing
or invalid. There are insufficient replicas for the pool to continue
functioning.
action: Destroy and re-create the pool from
a backup source.
see: http://www.sun.com/msg/ZFS-8000-5E
scan: none requested
config:
NAME STATE READ WRITE CKSUM
tank UNAVAIL 0 0 0 insufficient replicas
raidz1-0 UNAVAIL 0 0 0 insufficient replicas
sdb FAULTED 0 0 0 corrupted data
sdc FAULTED 0 0 0 corrupted data
sdd UNAVAIL 0 0 0
К счастью, это тестовый экземпляр, и поэтому я могу легко начать заново. Но что, если этот пул содержит важные данные? Что будет правильным следующим шагом (ами) для восстановления данных и восстановления моего NAS в рабочем состоянии? Или ZFS автоматически пробует все возможные подходы к восстановлению, так что теперь данные обновляются?
4 ответа
Похоже, ваш пул на самом деле не поврежден. Хотя, судя по выводу, могут возникнуть проблемы с несколькими устройствами. Я предполагаю, что несколько дисков могут быть в сомнительном состоянии, следовательно, неисправное состояние на SDB и SDC. Выясните, что может быть с ними не так, и ваш пул может доказать, что вы не правы. Это не похоже на фатальное состояние пула.
Вооружившись пониманием @slashdot, я в основном исправил свою проблему, но я действительно не знаю, что я сделал. Пожалуйста, изучите следующий след и просветите меня.
В частности, какая из следующих гипотез верна и что мне не хватает?
- ни
zdb -u tankниzdb -dcsv tankсделал что-нибудь полезное. - Второй
zpool import -f tankработал, когда первый не сделал, потому что прошло достаточно времени сzpool export tankчтобы у ZFS была возможность исправить себя. - Весь этот эпизод был связан с тем, что метки менялись после отказа одного из дисков (думаю, что это был sdb, вызвавший sdc>sdb & sdd>sdb).
ЖУРНАЛ
andy@ubuntu:~$ zpool status
andy@ubuntu:~$ sudo zpool status
pool: tank
state: UNAVAIL
status: One or more devices could not be used because the label is missing
or invalid. There are insufficient replicas for the pool to continue
functioning.
action: Destroy and re-create the pool from
a backup source.
see: http://www.sun.com/msg/ZFS-8000-5E
scan: none requested
config:
NAME STATE READ WRITE CKSUM
tank UNAVAIL 0 0 0 insufficient replicas
raidz1-0 UNAVAIL 0 0 0 insufficient replicas
sdb FAULTED 0 0 0 corrupted data
sdc FAULTED 0 0 0 corrupted data
sdd UNAVAIL 0 0 0
andy@ubuntu:~$ sudo zdb -u tank
zdb: can't open 'tank': No such device or address
andy@ubuntu:~$ sudo zpool scrub tank
cannot scrub 'tank': pool is currently unavailable
andy@ubuntu:~$ sudo zdb -bcsv tank
zdb: can't open 'tank': No such device or address
andy@ubuntu:~$ sudo zpool export tank
andy@ubuntu:~$ sudo zpool import tank
cannot import 'tank': pool may be in use from other system
use '-f' to import anyway
andy@ubuntu:~$ sudo zpool import -f tank
cannot import 'tank': one or more devices is currently unavailable
andy@ubuntu:~$ sudo zpool status
no pools available
andy@ubuntu:~$ sudo zpool status -x
no pools available
andy@ubuntu:~$ sudo zpool import
pool: tank
id: 9117894036185671023
state: UNAVAIL
status: One or more devices contains corrupted data.
action: The pool cannot be imported due to damaged devices or data.
see: http://www.sun.com/msg/ZFS-8000-5E
config:
tank UNAVAIL insufficient replicas
raidz1-0 UNAVAIL insufficient replicas
sdb FAULTED corrupted data
sdb UNAVAIL
sdc ONLINE
andy@ubuntu:~$ sudo zpool import tank
cannot import 'tank': pool may be in use from other system
use '-f' to import anyway
andy@ubuntu:~$ sudo zpool import -f tank
andy@ubuntu:~$ sudo zpool status
pool: tank
state: DEGRADED
status: One or more devices could not be used because the label is missing or
invalid. Sufficient replicas exist for the pool to continue
functioning in a degraded state.
action: Replace the device using 'zpool replace'.
see: http://www.sun.com/msg/ZFS-8000-4J
scan: scrub repaired 0 in 0h13m with 0 errors on Mon Nov 21 09:22:11 2011
config:
NAME STATE READ WRITE CKSUM
tank DEGRADED 0 0 0
raidz1-0 DEGRADED 0 0 0
10820373921989571629 UNAVAIL 0 0 0 was /dev/sdb1
sdb ONLINE 0 0 0
sdc ONLINE 0 0 0
errors: No known data errors
andy@ubuntu:~$
Я думаю, что предыдущие плакаты выдвинули на первый план проблему. Вероятная причина была связана с тем, как вы указали диски.
Мой опыт работы с ZFS на Ubuntu. Хотя я и использую ZFS на freenas, мне никогда не приходилось углубляться в реализацию bsd.
Конечно, для Ubuntu настоятельно рекомендуется указывать идентификатор устройства, а не дескриптор: то есть строку /dev/disk/by-id/scsi-SATA-long, которая уникально идентифицирует физический диск, а не / dev / sda.
Использование устройства by-id устраняет любую зависимость от конкретного порта SATA, к которому подключен диск.
Gareth
Вы можете просто перепутать диски?
Однажды я перепутал диски и zpool сказал: "Диски содержат поврежденные данные". После того, как я подключил диски в предыдущей последовательности, он начал работать.
Может быть, после того, как вы импортировали танк, zpool распознал правильную последовательность.