Estoy ejecutando este script basado en el procedimiento de configuración de ArchWiki . Falla en el paso de configuración de GRUB
Estoy usando el archlinux-2013.12.01-dual.iso dentro de VMware Player con 1 GB de RAM, sda
es de 810 MB. También he montado un recurso compartido CIFS en la máquina host.
# DEV=sda
# PART=sda1
# echo "1,,L,*" | sfdisk /dev/$DEV
# mkfs.ext3 /dev/$PART
# mount /dev/$PART /mnt
# pacstrap -i /mnt base
# genfstab -U -p /mnt >> /mnt/etc/fstab
# arch-chroot /mnt
# pacman -S grub
# pacman -S os-prober
# grub-mkconfig -o /boot/grub/grub.cfg
Yo obtengo:
Generating grub configuration file ...
Found linux image: /boot/vmlinuz-linux
Found initrd image: /boot/initramfs-linux.img
/run/lvm/lvmetad.socket: connect failed: No such file or directory
WARNING: Failed to connect to lvmetad: No such file or directory. Falling back to internal scanning.
/run/lvm/lvmetad.socket: connect failed: No such file or directory
/run/lvm/lvmetad.socket: connect failed: No such file or directory
No volume groups found
error: out of memory.
error: syntax error.
error: Incorrect command.
error: syntax error.
Syntax error at line 164
Syntax errors are detected in generated GRUB config file.
Ensure that there are no errors in /etc/default/grub
and /etc/grub.d/* files or please file a bug report with
/boot/grub/grub.cfg.new file attached.done
No instalé particiones / unidades LVM.
# fdisk -l /dev/sda
Disk /dev/sda: 819 MiB, 858783744 bytes, 1677312 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
Disklabel type: dos
Disk identifier: 0x000d5a2a
Device Boot Start End Blocks Id System
/dev/sda1 2048 1677311 837632 83 Linux
# lsblk
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
fd0 2:0 1 4K 0 disk
sda 8:0 0 819M 0 disk
└─sda1 8:1 0 818M 0 part /mnt
sr0 11:0 1 522M 0 rom /run/archiso/bootmnt
sr1 11:1 1 10M 0 rom
loop0 7:0 0 224.2M 1 loop /run/archiso/sfs/root-image
loop1 7:1 0 1.4G 1 loop
└─arch_root-image 254:0 0 1.4G 0 dm /
loop2 7:2 0 1.4G 0 loop
└─arch_root-image 254:0 0 1.4G 0 dm /
/boot/grub/grub.cfg.new
es:
#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#
### BEGIN /etc/grub.d/00_header ###
insmod part_gpt
insmod part_msdos
if [ -s $prefix/grubenv ]; then
load_env
fi
if [ "${next_entry}" ] ; then
set default="${next_entry}"
set next_entry=
save_env next_entry
set boot_once=true
else
set default="0"
fi
if [ x"${feature_menuentry_id}" = xy ]; then
menuentry_id_option="--id"
else
menuentry_id_option=""
fi
export menuentry_id_option
if [ "${prev_saved_entry}" ]; then
set saved_entry="${prev_saved_entry}"
save_env saved_entry
set prev_saved_entry=
save_env prev_saved_entry
set boot_once=true
fi
function savedefault {
if [ -z "${boot_once}" ]; then
saved_entry="${chosen}"
save_env saved_entry
fi
}
function load_video {
if [ x$feature_all_video_module = xy ]; then
insmod all_video
else
insmod efi_gop
insmod efi_uga
insmod ieee1275_fb
insmod vbe
insmod vga
insmod video_bochs
insmod video_cirrus
fi
}
if [ x$feature_default_font_path = xy ] ; then
font=unicode
else
insmod part_msdos
insmod ext2
set root='hd0,msdos1'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1 9d1d349e-d061-4e0f-9312-be19ca2dcb74
else
search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
fi
font="/usr/share/grub/unicode.pf2"
fi
if loadfont $font ; then
set gfxmode=auto
load_video
insmod gfxterm
set locale_dir=$prefix/locale
set lang=en_US
insmod gettext
fi
terminal_input console
terminal_output gfxterm
set timeout=5
### END /etc/grub.d/00_header ###
### BEGIN /etc/grub.d/10_linux ###
menuentry 'Arch Linux, with Linux core repo kernel' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-core repo kernel-true-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
load_video
set gfxpayload=keep
insmod gzio
insmod part_msdos
insmod ext2
set root='hd0,msdos1'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1 9d1d349e-d061-4e0f-9312-be19ca2dcb74
else
search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
fi
echo 'Loading Linux core repo kernel ...'
linux /boot/vmlinuz-linux root=UUID=9d1d349e-d061-4e0f-9312-be19ca2dcb74 rw quiet
echo 'Loading initial ramdisk ...'
initrd /boot/initramfs-linux.img
}
menuentry 'Arch Linux, with Linux core repo kernel (Fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-core repo kernel-fallback-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
load_video
set gfxpayload=keep
insmod gzio
insmod part_msdos
insmod ext2
set root='hd0,msdos1'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1 9d1d349e-d061-4e0f-9312-be19ca2dcb74
else
search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
fi
echo 'Loading Linux core repo kernel ...'
linux /boot/vmlinuz-linux root=UUID=9d1d349e-d061-4e0f-9312-be19ca2dcb74 rw quiet
echo 'Loading initial ramdisk ...'
initrd /boot/initramfs-linux-fallback.img
}
menuentry 'Arch Linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
load_video
set gfxpayload=keep
insmod gzio
insmod part_msdos
insmod ext2
set root='hd0,msdos1'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1 9d1d349e-d061-4e0f-9312-be19ca2dcb74
else
search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
fi
echo 'Loading Linux core repo kernel ...'
linux /boot/vmlinuz-linux root=UUID=9d1d349e-d061-4e0f-9312-be19ca2dcb74 rw quiet
echo 'Loading initial ramdisk ...'
initrd /boot/initramfs-linux-fallback.img
}
submenu 'Advanced options for Arch Linux' $menuentry_id_option 'gnulinux-advanced-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
### END /etc/grub.d/10_linux ###
### BEGIN /etc/grub.d/20_linux_xen ###
### END /etc/grub.d/20_linux_xen ###
### BEGIN /etc/grub.d/30_os-prober ###
### END /etc/grub.d/30_os-prober ###
### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries. Simply type the
# menu entries you want to add after this comment. Be careful not to change
# the 'exec tail' line above.
### END /etc/grub.d/40_custom ###
### BEGIN /etc/grub.d/41_custom ###
if [ -f ${config_directory}/custom.cfg ]; then
source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f $prefix/custom.cfg ]; then
source $prefix/custom.cfg;
fi
### END /etc/grub.d/41_custom ###
### BEGIN /etc/grub.d/60_memtest86+ ###
### END /etc/grub.d/60_memtest86+ ###
arch-linux
partition
lvm
grub2
antonio
fuente
fuente
archlinux-2013.12.01-dual.iso
dentro de VMware Player con 384 MB de RAM.sda
es de 810 MB. En un ISO secundario,sr1
ejecuté un script para instalar Vim y montar un recurso compartido CIFS en la máquina host.Respuestas:
Me encontré con el mismo problema en este momento, y encontré otra solución. Básicamente, implica hacer que el
/run
directorio de hosts esté disponible para el invitado.Primero, montamos
/run
donde el invitado pueda acceder. Asumiré que su partición de instalación está montada en/mnt
Luego, nos internamos en el invitado y montamos nuestro anfitrión
/run/lvm
en el invitado/run
Luego puede ejecutar
grub-mkconfig
ygrub-install
sin errores de LVM. Esto también hace que los comandos se comporten si está instalando con LVM, por lo que vale.Cuando termine, recuerde
umount /run/lvm
antesexit
de cortar el chroot.fuente
Después de la investigación desencadenada por @guest, descubrí que hay un error aparente en el
grub-mkconfig
script de ayuda/etc/grub.d/10_linux
, lo que hace que la entrada de respaldo GRUB initramfs no sea compatible con el sistema de submenú GRUB. Como el uso de un initramfs alternativo es muy específico para Arch y derivados, no es compatible con upstreamgrub-mkconfig
. Una solución definitiva todavía está en progreso. Ver más detalles en bugs.archlinux.orgPor lo tanto, una solución temporal es deshabilitar los submenús en GRUB al agregar:
a
/etc/default/grub
.Desafortunadamente, al deshabilitar los submenús, evito solo el segundo error generado por
grub-mkconfig
.Entonces, con:
Todavía consigo:
Nunca he instalado particiones / unidades LVM y, como puede ver en mi pregunta, particioné y formateé el sistema. De todos modos, después de corregir el error GRUB, probé ambos:
y
Y corrí
pacstrap
otra vez, sin éxito.El error actual no es crítico como
funciona sin problemas y puedo arrancar desde
$DEV
.fuente
Tuve el mismo problema pero encontré una solución que funciona para mí: simplemente eliminar
os-prober
.fuente
chmod -x /etc/grub.d/30_os-prober
y debería eliminar la advertencia.Agregar la línea GRUB_DISABLE_SUBMENU = y a / etc / default / grub podría ayudar
fuente: https://bbs.archlinux.org/viewtopic.php?pid=1357765
fuente
Para el primer mensaje de error, grub no puede conectarse al demonio de metadatos LVM, intente ejecutar este comando como root (que lo iniciará):
systemctl start lvmetad
Y el segundo, intente aumentar la RAM asignada a su VM, tal vez
512M
, y vuelva a ejecutar grub.fuente
systemctl start lvmetad
(ejecutar fuera de chroot) no da ningún mensaje de error. Pero volver a ejecutargrub-mkconfig
dentroarch-chroot
da exactamente el mismo error (incluido el error mem).