Falha ao carregar rootfs: Ubuntu 10 + grub2 + rootfs ext4 com RAID1

Falha ao carregar rootfs: Ubuntu 10 + grub2 + rootfs ext4 com RAID1

Estou tendo problemas para inicializar uma nova instalação do Ubuntu 10 (servidor). Meu HD principal (/dev/sda) está organizado da seguinte forma:

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *           1          18      144553+  83  Linux                  <-- /BOOT
/dev/sda2              19      182401  1464991447+   5  Extended
/dev/sda5              19        2207    17583111   fd  Linux raid autodetect
/dev/sda6            2208       11934    78132096   fd  Linux raid autodetect  <-- / (ROOTFS)
/dev/sda7           11935      182401  1369276146   fd  Linux raid autodetect

O rootfs faz parte de um array RAID1 (software) (atualmente degradado):

# cat /proc/mdstat
Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10]
md2 : active raid1 sda6[1]
      78132032 blocks [2/1] [_U]

Os UUIDs para as partições são os seguintes:

# blkid /dev/sda1
/dev/sda1: UUID="b25dd301-41b9-4f4d-9b0a-0e31713dd74c" TYPE="ext2"
# blkid /dev/sda6
/dev/sda6: UUID="af7b9ede-fa53-c0c1-74be-31ec752c5cd5" TYPE="linux_raid_member"
# blkid /dev/md2
/dev/md2: UUID="a0602d42-6855-482f-870c-6f6ecdcdae3f" TYPE="ext4"

Finalmente, tenho minha entrada de menu grub2 configurada da seguinte maneira:

### BEGIN /etc/grub.d/10_linux ###
menuentry 'Ubuntu, with Linux 2.6.32-25-server' --class ubuntu --class gnu-linux --class gnu --class os {
        insmod ext2
        insmod raid
        insmod mdraid
        set root='(hd0,1)'
        search --no-floppy --fs-uuid --set b25dd301-41b9-4f4d-9b0a-0e31713dd74c
        linux   /vmlinuz-2.6.32-25-server root=UUID=a0602d42-6855-482f-870c-6f6ecdcdae3f ro   nosplash noplymouth
        initrd  /initrd.img-2.6.32-25-server
}

Quando tento inicializar, o grub carrega OK, mas acabo recebendo a seguinte mensagem de erro:

Gave up waiting for root device. Common problems:
  — Boot args (cat /proc/cmdline)
    — Check rootdelay= (did the system wait long enough?)
    — Check root= (did the system wait for the right device?)
  — Missing modules (cat /proc/modules; ls /dev)
ALERT! /dev/disk/by-uuid/a0602d42-6855-482f-870c-6f6ecdcdae3f does not exist.   
Dropping to a shell! 

Se a partir do bootloader grub eu abrir uma linha de comando grub>, posso ls (hd0) e ele lista as partições corretas com os UUIDs como mostrado acima - sda6 mostra 'a0602d42-6855-482f-870c-6f6ecdcdae3f' (o UUID RAID ). Se eu ls (md2)/ listar corretamente todos os arquivos no sistema de arquivos RAID1 (ext4), então não parece ser um problema ao acessar o dispositivo RAID.

Alguém tem alguma sugestão sobre qual pode ser o problema? Eu não consigo entender isso.

Responder1

Finalmente encontrei a resposta através do Google.

Eu tive que adicionar o parâmetro do kernel rootdelay=90à linux /vmlinuz...linha do arquivo grub.cfg.
O sistema então inicializa sem problemas. Não demora muito (talvez 30 segundos do POST ao prompt de login do Ubuntu). Parece ser uma solução alternativa pouco conhecida/pouco documentada para esse problema.

informação relacionada