Что делать с поврежденным пулом ZFS

5

Был запущен тестовый экземпляр NAS с использованием ZFS, как указано в Восстановление сервера Ubuntu с использованием ZFS RAIDZ для данных .

На этой неделе один из моих дисков умер. Не должно быть проблем, должно ли это (преимущества RAID как устойчивости, так и производительности)?

За исключением того, что мой пул ZFS поврежден, как в:

[email protected]:~$ 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 автоматически пытается использовать все возможные подходы к восстановлению, чтобы теперь данные были тостами?

    
задан andybjackson 28.01.2012 в 14:13
источник

4 ответа

1

Похоже, что ваш пул не может быть поврежден. Хотя на выходе кажется, что несколько устройств могут быть в беде. Я предполагаю, что несколько дисков могут находиться в сомнительном состоянии, следовательно, состояние с ошибкой на sdb и sdc. Выясните, что может быть с ними, и ваш пул может оказаться неправильным. Это не похоже на фатальное состояние пула.

    
ответ дан slashdot 30.01.2012 в 06:14
источник
3

Вооружившись пониманием @slashdot, я в основном исправил свою проблему, но я действительно не знаю, что я сделал. Пожалуйста, изучите следующий след и просветите меня.

В частности, какая из следующих гипотез истинна и что мне не хватает?

  1. Ни zdb -u tank , ни zdb -dcsv tank не сделали ничего полезного.
  2. Второй zpool import -f tank работал, когда первый не сделал, потому что прошло достаточно времени, так как zpool export tank для ZFS имеет возможность исправить себя.
  3. Весь этот эпизод имел какое-то отношение к ярлыкам, которые меняли сами после отказа одного из дисков (думаю, это был sdb, который вызвал sdc > sdb & amp; sdd > sdb).

LOG

[email protected]:~$ zpool status
[email protected]:~$ 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
[email protected]:~$ sudo zdb -u tank
zdb: can't open 'tank': No such device or address
[email protected]:~$ sudo zpool scrub tank
cannot scrub 'tank': pool is currently unavailable
[email protected]:~$ sudo zdb -bcsv tank
zdb: can't open 'tank': No such device or address
[email protected]:~$ sudo zpool export tank
[email protected]:~$ sudo zpool import tank
cannot import 'tank': pool may be in use from other system
use '-f' to import anyway
[email protected]:~$ sudo zpool import -f tank
cannot import 'tank': one or more devices is currently unavailable
[email protected]:~$ sudo zpool status
no pools available
[email protected]:~$ sudo zpool status -x
no pools available
[email protected]:~$ 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
[email protected]:~$ sudo zpool import tank
cannot import 'tank': pool may be in use from other system
use '-f' to import anyway
[email protected]:~$ sudo zpool import -f tank
[email protected]:~$ 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
[email protected]:~$
    
ответ дан andybjackson 03.02.2012 в 21:52
1

Вы просто перепутали диски?

Как только я перепутал диски и zpool сказал, что «диски содержат поврежденные данные». После того, как я подключил диски в предыдущей последовательности, он начал работать.

Возможно, после того, как вы импортировали цистерну zpool, распознали правильную последовательность.

    
ответ дан BBK 11.02.2012 в 19:12
1

Я думаю, что предыдущие плакаты осветили проблему. Вероятная причина была связана с тем, как вы указали диски.

Мой опыт работы с ZFS на Ubuntu. Хотя я и использую ZFS на freenas, мне никогда не приходилось вникать в реализацию bsd.

Конечно, для Ubuntu вам настоятельно рекомендуется указывать ваши устройства по-id, а не по дескриптору: ie / dev / disk / by-id / scsi-SATA-длинная строка, которая уникально идентифицирует физический диск, а не / dev / SDA.

Использование устройства by-id устраняет любую зависимость от конкретного порта SATA, к которому подключен диск.

Гарет

    
ответ дан Gareth 03.06.2013 в 15:06