Eu tenho uma máquina que costumava inicializar o Ubuntu duas vezes (16.04 atualmente) e o Windows 7, com o GRUB do Ubuntu como carregador de inicialização.
Agora acabei de adicionar o Arch Linux como terceiro sistema operacional, seguindo as instruções oficiais de instalação. Não instalei o GRUB a partir do Arch, porque queria usar o controlado pelo Ubuntu. As instruções continham um comando mkinitcpio -p linux
que provavelmente gerou alguns arquivos de inicialização que executei conforme descrito.
Agora, quando tento inicializar o Ubuntu a partir do GRUB por meio da entrada padrão, recebo este erro desagradável (desculpe pela foto da tela):
Como resultado do uname -a
show, ele está tentando inicializar o kernel do Arch, mas /dev/sda6
é a partição raiz do Ubuntu.
Eu tenho que navegar Advanced options for Ubuntu
e selecionar uma das Ubuntu, with Linux 4.4.0-*
entradas para poder carregar o Ubuntu, mas não consegui encontrar uma entrada que carregasse corretamente o Arch.
A execução sudo update-grub
no Ubuntu ( " update-grub
é um esboço para a execução grub-mkconfig -o /boot/grub/grub.cfg
de um arquivo de configuração do grub2." ) Não muda nada. A grub-customizer
ferramenta também foi inútil para corrigir isso até agora.
O que causa essa confusão do GRUB e como corrigi-lo para que cada versão do Linux seja inicializada com o kernel correto e a partição correta?
Parece que eu estupidamente instalei o Arch com o Ubuntu / boot montado, então provavelmente colocou seus arquivos de inicialização lá.
Eu estou bem em apagar todas as coisas relacionadas ao Arch para obter o gerenciador de inicialização do Ubuntu novamente e fazer uma instalação limpa do Arch mais tarde.
Atualizações (obrigado a @terdon por seu apoio no chat Ask Ubuntu):
Aqui está o meu /boot/grub/grub.cfg
.
Todas as entradas do Linux parecem apontar para minha partição / dev / sda6, que é a raiz do Ubuntu:
$ grep ' linux /' /boot/grub/grub.cfg
linux /vmlinuz-linux root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro
linux /vmlinuz-linux root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro
linux /vmlinuz-linux root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro
linux /vmlinuz-linux root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro init=/sbin/upstart
linux /vmlinuz-linux root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro recovery nomodeset
linux /vmlinuz-4.4.0-21-generic root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro
linux /vmlinuz-4.4.0-21-generic root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro init=/sbin/upstart
linux /vmlinuz-4.4.0-21-generic root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro recovery nomodeset
linux /vmlinuz-4.2.0-35-generic root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro
linux /vmlinuz-4.2.0-35-generic root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro init=/sbin/upstart
linux /vmlinuz-4.2.0-35-generic root=UUID=eee18451-b607-4875-8a88-c9cb6c6544c8 ro recovery nomodeset
Eu tentei atualizar a configuração do GRUB no Ubuntu:
$ sudo grub-mkconfig -o /boot/grub/grub.cfg
Generating grub configuration file ...
dpkg: warning: version 'linux' has bad syntax: version number does not start with a digit
Found linux image: /boot/vmlinuz-linux
Found initrd image: /boot/initramfs-linux.img
Found linux image: /boot/vmlinuz-4.4.0-21-generic
Found initrd image: /boot/initrd.img-4.4.0-21-generic
Found linux image: /boot/vmlinuz-4.2.0-35-generic
Found initrd image: /boot/initrd.img-4.2.0-35-generic
Found memtest86+ image: /memtest86+.elf
Found memtest86+ image: /memtest86+.bin
Found Windows 7 (loader) on /dev/sda1
Found Arch on /dev/sda8
done
Tentei reinstalar o GRUB no MBR do Ubuntu:
$ sudo grub-install /dev/sda
Installing for i386-pc platform.
Installation finished. No error reported.
$ sudo grub-install --recheck /dev/sda
Installing for i386-pc platform.
Installation finished. No error reported.
A propósito, esses são os pacotes de kernel do Ubuntu instalados, tentei dpkg-reconfigure
todos eles, mas sem qualquer efeito sobre o problema:
$ dpkg -l linux-image* | grep ^ii
ii linux-image-4.2.0-35-generic 4.2.0-35.40 amd64 Linux kernel image for version 4.2.0 on 64 bit x86 SMP
ii linux-image-4.4.0-21-generic 4.4.0-21.37 amd64 Linux kernel image for version 4.4.0 on 64 bit x86 SMP
ii linux-image-extra-4.2.0-35-generic 4.2.0-35.40 amd64 Linux kernel extra modules for version 4.2.0 on 64 bit x86 SMP
ii linux-image-extra-4.4.0-21-generic 4.4.0-21.37 amd64 Linux kernel extra modules for version 4.4.0 on 64 bit x86 SMP
Eu também tentei regenerar o initramfs do Ubuntu:
$ sudo update-initramfs -u -k all
update-initramfs: Generating /boot/initrd.img-4.4.0-21-generic
update-initramfs: Generating /boot/initrd.img-4.2.0-35-generic
Meu layout de partição:
Verificado a partir do sistema Ubuntu. Os rótulos devem se explicar.
$ lsblk -f /dev/sda
NAME FSTYPE LABEL UUID MOUNTPOINT
sda
├─sda1 ntfs win7-boot 90DCF3A5DCF3842E /win/boot
├─sda2 ntfs windows7 482C7A572C7A3FCC /win/c
├─sda3 ext4 grub-boot 6dbb8633-dadd-4b5e-8d85-b0895fde9dfb /boot
├─sda5 ext4 images 81dc42c4-a161-4ccd-b704-6e5c09298943 /images
├─sda6 ext4 ubuntu-1604 eee18451-b607-4875-8a88-c9cb6c6544c8 /
├─sda7 ext4 ubuntu-home 485b3ef1-7216-4053-b25c-f656d529e8e6 /home
├─sda8 ext4 arch-root 8d281a0c-969c-44cf-ba6a-1d3c7b4be7ec
├─sda9 ext4 arch-home 32522902-a53d-44c8-90f2-6bbf14c40f1f
└─sda10 swap linux-swap 8b05bd9b-bc42-46f6-8c18-50711a3c48b9 [SWAP]
Minha estrutura de menus do GRUB:
Opções avançadas para o Ubuntu:
Meu /boot
diretório:
$ ls -la /boot
total 118480
drwxr-xr-x 4 root root 4096 Apr 24 20:50 .
drwxr-xr-x 28 root root 4096 Apr 24 19:44 ..
-rw-r--r-- 1 root root 1313029 Mär 16 01:45 abi-4.2.0-35-generic
-rw-r--r-- 1 root root 1239577 Apr 19 00:21 abi-4.4.0-21-generic
-rw-r--r-- 1 root root 184888 Mär 16 01:45 config-4.2.0-35-generic
-rw-r--r-- 1 root root 189412 Apr 19 00:21 config-4.4.0-21-generic
drwxr-xr-x 6 root root 4096 Apr 26 19:58 grub
-rw-r--r-- 1 root root 18598360 Apr 24 20:59 initramfs-linux-fallback.img
-rw-r--r-- 1 root root 3516429 Apr 24 20:59 initramfs-linux.img
-rw-r--r-- 1 root root 33642388 Apr 24 18:31 initrd.img-4.2.0-35-generic
-rw-r--r-- 1 root root 36143341 Apr 24 19:51 initrd.img-4.4.0-21-generic
drwx------ 2 root root 16384 Okt 28 17:43 lost+found
-rw-r--r-- 1 root root 182704 Jan 28 13:44 memtest86+.bin
-rw-r--r-- 1 root root 184380 Jan 28 13:44 memtest86+.elf
-rw-r--r-- 1 root root 184840 Jan 28 13:44 memtest86+_multiboot.bin
-rw------- 1 root root 3745312 Mär 16 01:45 System.map-4.2.0-35-generic
-rw------- 1 root root 3853719 Apr 19 00:21 System.map-4.4.0-21-generic
-rw------- 1 root root 6829104 Mär 16 01:45 vmlinuz-4.2.0-35-generic
-rw------- 1 root root 7013968 Apr 19 00:21 vmlinuz-4.4.0-21-generic
-rw-r--r-- 1 root root 4435552 Apr 14 19:20 vmlinuz-linux
Os kernels 4.4.0 e 4.2.0 devem ser o Ubuntu, o Arch deve ter um kernel 4.5.0. Mas como descobrir qual arquivo sem a versão do kernel em seu nome pertence a quê?
Meu diretório raiz do Ubuntu (diretórios excluídos):
$ ls -la / | grep ^[^d]
total 124
lrwxrwxrwx 1 root root 32 Apr 24 19:44 initrd.img -> boot/initrd.img-4.4.0-21-generic
lrwxrwxrwx 1 root root 32 Apr 5 17:45 initrd.img.old -> boot/initrd.img-4.2.0-35-generic
lrwxrwxrwx 1 root root 29 Apr 24 19:44 vmlinuz -> boot/vmlinuz-4.4.0-21-generic
lrwxrwxrwx 1 root root 29 Apr 5 17:45 vmlinuz.old -> boot/vmlinuz-4.2.0-35-generic
Meu diretório raiz do Arch não contém nenhum arquivo ou link.
Root device mounted successfully, but /sbin/init does not exists
. Você investigou isso? Está init
realmente faltando? Em caso afirmativo, você deve instalá-lo definitivamente, se estiver presente, alguma idéia de por que não foi encontrado?
os-prober
. em seguida, executar estessudo mkinitcpio -p linux
, em seguida,sudo grub-mkconfig -o /boot/grub/grub.cfg
por últimosudo grub-install /dev/sda