Volume de LVM com MBR corrompido: como montar e recuperar dados dele?

3

Eu sou novo no LVM e particionamento em geral, e, portanto, estou em uma situação aqui.

A situação:

Eu acidentalmente gravei o MBR de um disco LVM criado pelo Fedora 16.

Agora, tudo mais neste disco está intacto; apenas o MBR foi corrompido (e também, apenas os primeiros 446 dos seus 512 bytes). Eu tinha corrompido o MBR por emissão acidental:

$ dd if=/the/wrong/446-byte-file.txt of=/dev/sda

Este disco (com MBR corrompido), que inicialmente era / dev / sda no Sistema A, agora está plugado em meu sistema atual, System B, como um disco secundário, /dev/sdb , para fins de recuperação de sistema de arquivos / dados. Atualmente, ele não pode ser montado no Sistema B.

Aqui está a saída fdisk -l no Sistema B:

$ fdisk -l
Disk /dev/sda: 250.1 GB, 250059350016 bytes
255 heads, 63 sectors/track, 30401 cylinders, total 488397168 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 4096 bytes
Disk identifier: 0x8e678e67

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048   475813887   237905920   83  Linux
/dev/sda2       475813888   488396799     6291456   82  Linux swap / Solaris

Disk /dev/sdb: 80.0 GB, 80026361856 bytes
255 heads, 63 sectors/track, 9729 cylinders, total 156301488 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000

   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1   *        2048     1026047      512000   83  Linux
/dev/sdb2         1026048   156301311    77637632   8e  Linux LVM

Pergunta: Com / dev / sda executando uma configuração do Fedora 16 que não seja do LVM, como eu monto manualmente o / dev / sdb (com MBR corrompido) em algum lugar dentro do System B para poder recuperar todos os dados dele? (Os dados, a propósito, são armazenados em um sistema de arquivos ext4).

O que tentei até agora:

a) Eu emiti pvs e recebi isto:

(observe como a coluna VG está vazia!)

$ pvs
  PV         VG   Fmt  Attr PSize  PFree 
  /dev/sdb2       lvm2 a--  74.04g 74.04g

b) eu emiti pvscan , eu tenho isso:

$ pvscan
  PV /dev/sdb2                      lvm2 [74.04 GiB]
  Total: 1 [74.04 GiB] / in use: 0 [0   ] / in no VG: 1 [74.04 GiB]

c) Eu tenho o conteúdo de /etc/lvm/backup/vg_XYZ disponível comigo de um backup anterior. Mas eu não sei como inferir / construir o Volume Name e o Volume Paths deste arquivo (Note que, neste arquivo, / dev / sda2 é a partição de interesse que agora se tornou / dev / sdb2 no sistema atual, Sistema B):

# Generated by LVM2 version 2.02.84(2) (2011-02-09): Tue Oct 25 22:10:55 2011

contents = "Text Format Volume Group"
version = 1

description = "Created *after* executing 'vgchange -a y --sysinit'"

creation_host = "XYZ"   # Linux XYZ 2.6.38.6-26.rc1.fc15.i686.PAE #1 SMP Mon May 9 20:36:50 UTC 2011 i686
creation_time = 1319560855      # Tue Oct 25 22:10:55 2011

vg_XYZ {
        id = "WN8593-xRnx-dn29-rcpb-tRAm-Bs5R-93DGWw"
        seqno = 3
        status = ["RESIZEABLE", "READ", "WRITE"]
        flags = []
        extent_size = 65536             # 32 Megabytes
        max_lv = 0
        max_pv = 0
        metadata_copies = 0

        physical_volumes {

                pv0 {
                        id = "voQHGq-9m5t-u39a-UBWP-1qKM-sS4M-t3EPYG"
                        device = "/dev/sda2"    # Hint only

                        status = ["ALLOCATABLE"]
                        flags = []
                        dev_size = 155275264    # 74.041 Gigabytes
                        pe_start = 2048
                        pe_count = 2369 # 74.0312 Gigabytes
                }
        }

        logical_volumes {

                lv_swap {
                        id = "Osi18q-409G-iG1s-Mdb2-00Lt-wtQV-WpF2mN"
                        status = ["READ", "WRITE", "VISIBLE"]
                        flags = []
                        segment_count = 1

                        segment1 {
                                start_extent = 0
                                extent_count = 126      # 3.9375 Gigabytes

                                type = "striped"
                                stripe_count = 1        # linear

                                stripes = [
                                        "pv0", 0
                                ]
                        }
                }

                lv_root {
                        id = "Wc8qdx-sYKi-qFeM-Bv48-YvZC-ClGU-VrYl4W"
                        status = ["READ", "WRITE", "VISIBLE"]
                        flags = []
                        segment_count = 1

                        segment1 {
                                start_extent = 0
                                extent_count = 2243     # 70.0938 Gigabytes

                                type = "striped"
                                stripe_count = 1        # linear

                                stripes = [
                                        "pv0", 126
                                ]
                        }
                }
        }
}

Sua pronta ajuda seria muito apreciada, senão estou em apuros!

Muito obrigado antecipadamente ...

/ HS

    
por Harry 12.04.2012 / 18:26

3 respostas

3

Experimente os seguintes passos na ordem.

EDIT (por Harry)

  1. Teve que executar vgcfgrestore para o restante dos comandos listados abaixo (começando com vgscan ) para entrar em vigor.

    vgcfgrestore vg_XYZ

  2. Também precisou de um e2fsck -y /dev/vg_XYZ/lv_root para a montagem ser bem-sucedida.

Detalhes descritos nesta postagem de comp.os.linux.setup aqui .

Como você já fez um pvscan , prossiga para um vgscan :

vgscan --partial --mknodes --verbose

Com sorte, isso deve descobrir o grupo de volumes vg_XYZ on /dev/sdb2 e criar todos os nós de dispositivos necessários em /dev .

Em seguida, disponibilize o grupo de volumes:

vgchange -a y vg_XYZ

Siga com um lvscan :

lvscan --verbose

E, finalmente, disponibilize o volume lógico:

lvchange -a y vg_XYZ/lv_root

Agora você deve conseguir montar lv_root em algum lugar para acessar seus dados, por exemplo,

mkdir -p /mnt/rescue
mount -t ext4 -o ro /dev/vg_XYZ/lv_root /mnt/rescue

Boa sorte!

    
por 12.04.2012 / 19:27
2

o PartedMagic liveCD / USB tem todos os tipos de ferramentas que podem recuperar o MBR daquele disco . testdisk é um , e eu sei que existem outros. Ele salvou minha pele algumas vezes de comandos mal digitados, há uma razão dd é apelidada de disk destroyer .

    
por 12.04.2012 / 18:44
1

Você pode criar o dispositivo manualmente usando os números encontrados no arquivo de backup.

dmsetup create foo --table "0 146997248 linear /dev/sdb2 8259584"
mount -o ro /dev/mapper/foo /mnt

Os números são calculados como:

146997248 = extent_count * extent_size = 2243 * 65536
8259584 = pe_start + 126 * extent_size = 2048 + 126 * 65536

Isso é UNTESTED. Se o backup não fornecer uma imagem precisa da configuração atual (ou se eu tiver os cálculos errados - eu os reproduzi por analogia com a configuração local em vez de um entendimento suficientemente profundo do LVM), então não funcionará .

    
por 12.04.2012 / 20:17