Failed to mount /sysroot - Error al iniciar VM en VirtualBox
Hola.
Me encontré con este error en VirtualBox al iniciar mi máquina virtual de Oracle Linux.
Es importante mencionar que este error me ocurrió después de que mi computadora host se trabó con la VM corriendo y tuve que reiniciarla con el clásico botonazo. Es decir que no la apagué correctamente y al intentar prenderla obtengo el siguiente error:
[ 10.658694] BTRFS: failed to read tree root on sda3
[ 10.665086] BTRFS: open_ctree failed
[FAILED] Failed to mount /sysroot.
See 'systemctl status sysroot.mount' for details.
[DEPEND] Dependency failed for Initrd Root File System.
[DEPEND] Dependency failed for Reload Configuration from the Real Root.
[ OK ] Stopped dracut pre-udev hook.
[ OK ] Stopped dracut cmdline hook.
[ OK ] Stopped dracut initqueue hook.
[ OK ] Reached target Initrd File Systems.
[ OK ] Stopped target Basic System.
[ OK ] Stopped target System Initialization.
[ OK ] Started Emergency Shell.
[ OK ] Reached target Emergency Mode.
Generating "/run/initramfs/rdsosreport.txt"
Entering emergency mode. Exit the shell continue.
Type "journalctl" to view system logs.
You might want to save "/run/initramfs/rdsosreport.txt" to a USB stick or /boot after mounting them and attach it to a bug report.
:/#
Como lo describe el error existe un error en la partición sda3. De acuerdo a cómo sucedió el error se puede inferir que es una corrupción de archivos en esa partición que impide el inicio del sistema.
Al intentar verificar el estado de esa partición con la instrucción btrfs check /dev/sda3 obtengo lo siguiente:
parent transid verify failed on 165429248 wanted 13999 found 13453
parent transid verify failed on 165429248 wanted 13999 found 13453
parent transid verify failed on 165429248 wanted 13999 found 13453
parent transid verify failed on 165429248 wanted 13999 found 13453
Ignoring transid failure
Couldn't setup extent tree
ERROR: cannot open file system
Como sugiere la primera descripción del error intento el comando systemctl status sysroot.mount. Esto me da toda la información del error que necesito para continuar.
Ojo: Es muy importante tomar en cuenta que se puede perder información al ejecutar este comando por lo que sugiero mucho que hagan una copia de respaldo antes de intentar esto. Lo que yo hice fue clonar mi máquina virtual antes de esto en caso de no poder recuperarla.
El comando es: mount -t btrfs -o recovery,nospace_cache,clear_cache DEVICE MOUNTPOINT donde DEVICE es /dev/sda3 y MOUNTPOINT es /sysroot en mi caso.
:/# mount -t btrfs -o recovery,nospace_cache,clear_cache /dev/sda3 /sysroot
Una vez ejecutada el comando obtengo esta salida:
Después de esto apago la máquina con init 0 y la vuelvo a iniciar.
Con esto ya puedo acceder nuevamente a mi maquina virtual.
Les dejo link del video del procedimiento: https://youtu.be/UrEPbQikLPY
Espero les sirva.