GRUB (Português)
GRUB (GRand Unified Bootloader) é um gerenciador de boot. O GRUB atual também é chamado de GRUB 2. O GRUB original, ou GRUB Legacy, corresponde às versões 0.9x. Esta página descreve exclusivamente o GRUB 2.
esp
denota o ponto de montagem da partição de sistema EFI, comumente abreviada como ESP.Sistemas UEFI
- É recomendável ler e entender as páginas Unified Extensible Firmware Interface, Particionamento#Tabela de Partição GUID e Processo de inicialização do Arch#No UEFI.
- Ao instalar o UEFI, é importante inicializar a mídia de instalação no modo UEFI, caso contrário o efibootmgr não poderá adicionar a entrada de inicialização UEFI do GRUB. A instalação no caminho de inicialização reserva continuará funcionando mesmo no modo BIOS, já que ele não toca na NVRAM.
- Para inicializar a partir de um disco usando UEFI, é necessária uma partição de sistema EFI. Siga Partição de sistema EFI#Verificar uma partição existente para descobrir se você já tem uma, caso contrário você precisa criá-la.
- Este artigo inteiro assume que é possível inserir módulos GRUB2 adicionais via
insmod
. Conforme discutido em Unified Extensible Firmware Interface/Secure Boot#shim with key and GRUB, esse não é o caso em sistemas UEFI com Secure Boot ativado. Se você quiser usar qualquer módulo GRUB adicional que não esteja incluído no arquivo GRUB EFI padrãogrubx64.efi
em um sistema de inicialização segura, será necessário gerar novamente o GRUB EFIgrubx64.efi
comgrub-mkstandalone
com os módulos GRUB adicionais incluídos.
Instalação
- Os firmwares da UEFI não são implementados de forma consistente entre os fabricantes. O procedimento descrito abaixo destina-se a funcionar em uma ampla variedade de sistemas UEFI, mas os que enfrentam problemas, apesar de aplicarem esse método, são encorajados a compartilhar informações detalhadas e, se possível, as soluções alternativas encontradas para o caso específico do hardware. Um artigo /Exemplos de EFI foi fornecido para esses casos.
- A seção supõe que você esteja instalando o GRUB para sistemas x86_64. Para sistemas UEFI IA32 (32 bits) (não confundir com CPUs de 32 bits), substitua
x86_64-efi
pori386-efi
onde apropriado. - Veja Secure Boot para instruções sobre como implementá-lo.
Primeiro, instale os pacotes grub e efibootmgr: GRUB é o gerenciador de boot, enquanto efibootmgr é usado pelo script de instalação do GRUB para escrever entradas de inicialização para NVRAM.
Então, siga os seguintes passos para instalar o GRUB em seu disco:
- Monte a partição de sistema EFI e, no restante da sessão, substitua
esp
com seu ponto de montagem. - Escolha um identificador de gerenciador de boot, aqui chamado
GRUB
. Um diretório com esse nome será criado emesp/EFI/
para armazenar o binário EFI e esse é o nome que aparecerá no menu de inicialização UEFI para identificar a entrada de inicialização do GRUB. - Execute o seguinte comando para instalar o aplicativo EFI do GRUB
grubx64.efi
emesp/EFI/GRUB/
e instalar seus módulos para/boot/grub/x86_64-efi/
. {{Nota|Certifique-se de instalar os pacotes e executar o comandogrub-install
do sistema no qual o GRUB será instalado como o gerenciador de boot. Isso significa que se você estiver inicializando a partir do ambiente de instalação live, você precisa estar dentro do chroot quando estiver executandogrub-install
. Se por algum motivo for necessário executargrub-install
de fora do sistema instalado, anexe a opção--boot-directory=
com o caminho para o/boot
, por exemplo,--boot-directory=/mnt/boot
.# grub-install --target=x86_64-efi --efi-directory=esp --bootloader-id=GRUB
Após a conclusão da instalação acima, o diretório principal do GRUB está localizado em /boot/grub/
. Leia GRUB/Tips and tricks#Alternative install method para saber como especificar um local alternativo. Note que grub-install
também tenta criar uma entrada no gerenciador de boot do firmware, chamado GRUB
no exemplo acima -– isso pode, no entanto, falhar se suas entradas de inicialização estiverem lotadas; use efibootmgr para remover entradas desnecessárias.
Lembre-se de gerar o arquivo de configuração principal após finalizar a configuração.
--removable
, o GRUB será instalado em esp/EFI/BOOT/BOOTX64.EFI
(ou esp/EFI/BOOT/BOOTIA32.EFI
para o alvo i386-efi
e você terá a capacidade adicional de poder inicializar a partir da unidade caso as variáveis EFI sejam reiniciadas ou você mover a unidade para outro computador. Normalmente, você pode fazer isso selecionando a unidade em si de forma semelhante ao uso da BIOS. Se estiver usando dual boot com o Windows, esteja ciente de que o Windows geralmente coloca um executável EFI lá, mas sua única finalidade é recriar a entrada de inicialização do UEFI para o Windows. Se você está instalando o GRUB em um Mac, você terá que usar esta opção.--efi-directory
e--bootloader-id
são específicos para UEFI do GRUB,--efi-directory
substitui--root-directory
que está obsoleto.- Você pode notar a ausência de uma opção caminho_dispositivo (por exemplo:
/dev/sda
) no comandogrub-install
. Na verdade, qualquer caminho_dispositivo fornecido será ignorado pelo script de instalação do GRUB UEFI. De fato, os gerenciadores de boot de UEFI não usam um código de inicialização da MBR ou um setor de inicialização de partição.
Veja a solução de problemas do UEFI caso tenha problemas. Além disso, veja GRUB/Tips and tricks#UEFI further reading.
Sistemas BIOS
Instruções específicas de Tabela de Partição GUID (GPT)
Em uma configuração de BIOS/GPT, é necessária uma partição de inicialização de BIOS. O GRUB incorpora seu core.img
nessa partição.
- Antes de tentar este método, lembre-se de que nem todos os sistemas poderão ter suporte a este esquema de particionamento. Leia mais sobre Particionamento#Tabela de Partição GUID.
- A partição de inicialização de BIOS é necessária apenas pelo GRUB em uma configuração de BIOS/GPT. Em uma configuração de BIOS/MBR, o GRUB usa a lacuna pós-MBR para a incorporação do
core.img
. No GPT, no entanto, não há espaço não utilizado garantido antes da primeira partição. - Para sistemas UEFI, essa partição extra não é necessária, pois não há incorporação de setores de inicialização nesse caso. No entanto, os sistemas UEFI ainda requerem uma partição de sistema EFI.
Crie uma partição de mebibyte (+1M
com fdisk ou gdisk) no disco sem sistema de arquivos e com o tipo de partição GUID 21686148-6449-6E6F-744E-656564454649
.
- Selecione o tipo de partição
BIOS inicialização
para fdisk. - Selecione o código de tipo de partição
ef02
para gdisk. - Para o parted defina/ative a opção
bios_grub
a partição.
Esta partição pode estar em qualquer ordem de posição, mas deve estar nos primeiros 2 TiB do disco. Esta partição precisa ser criada antes da instalação do GRUB. Quando a partição estiver pronta, instale o gerenciador de boot conforme as instruções abaixo.
O espaço antes da primeira partição também pode ser usado como partição de inicialização de BIOS, embora esteja fora da especificação de alinhamento da GPT. Como a partição não será acessada regularmente, problemas de desempenho podem ser desconsiderados, embora alguns utilitários de disco exibam um aviso sobre isso. Em fdisk ou gdisk crie uma nova partição a partir do setor 34 e abrangendo até 2047 e defina o tipo. Para que as partições visualizáveis comecem na base, considere adicionar essa partição por último.
Instruções específicas de Master Boot Record (MBR)
Normalmente, o intervalo pós-MBR (após a região de 512 bytes MBR e antes do início da primeira partição) em muitos sistemas particionados MBR é de 31 KiB quando os problemas de alinhamento do cilindro de compatibilidade do DOS são atendidos na tabela de partições. No entanto, uma lacuna pós-MBR de cerca de 1 a 2 MiB é recomendada para fornecer espaço suficiente para incorporar o core.img
do GRUB (FS#24103). É aconselhável usar uma ferramenta de particionamento que suporte alinhamento de partições de 1 MiB para obter este espaço, bem como para satisfazer outros problemas de setor não-512-byte (que não estão relacionados à incorporação de core.img
).
Instalação
Instale o pacote grub. (Ele vai substituir o grub-legacyAUR se este ainda estiver instalado.) Então, execute:
# grub-install --target=i386-pc /dev/sdX
sendo i386-pc
usado deliberadamente, independentemente de sua arquitetura real, e /dev/sdX
o disco (não a partição) no qual o GRUB deve ser instalado. Por exemplo, o disco /dev/sda
ou /dev/nvme0n1
ou /dev/mmcblk0
. Veja Arquivo de dispositivo#Nomes de dispositivos de bloco para uma descrição do esquema de nomeação de dispositivo de bloco.
Agora, você deve gerar o arquivo de configuração principal.
Se você usa LVM para seu /boot
, você pode instalar o GRUB em vários discos físicos.
Veja grub-install(8) e o manual do GRUB para mais detalhes no comando grub-install
.
Configuração
Em um sistema instalado, o GRUB carrega o arquivo de configuração /boot/grub/grub.cfg
em cada inicialização. Você pode seguir #grub.cfg gerado para usar uma ferramenta ou #grub.cfg personalizado para uma criação manual.
grub.cfg gerado
Esta seção cobre apenas a edição do arquivo de configuração /etc/default/grub
. Veja GRUB/Tips and tricks para mais informações.
/etc/default/grub
e/ou arquivos em /etc/grub.d/
.Gerar o arquivo de configuração principal
Após a instalação, o arquivo de configuração principal /boot/grub/grub.cfg
precisa ser gerado. O processo de geração pode ser influenciado por uma variedade de opções em /etc/default/grub
e scripts em /etc/grub.d/
.
Se você não tiver feito configurações adicionais, a geração automática determinará o sistema de arquivos raiz do sistema para inicializar o arquivo de configuração. Para que isso seja bem sucedido, é importante que o sistema seja inicializado ou "chrooted".
- O caminho do arquivo padrão é
/boot/grub/grub.cfg
, não/boot/grub/i386-pc/grub.cfg
. - Se você está tentando executar o grub-mkconfig em um chroot ou em um contêiner systemd-nspawn, você pode notar que ele não funciona:
grub-probe: failed to get canonical path of /dev/sdaX
. Neste caso, tente usar arch-chroot como descrito nesta publicação no BBS.
Use a ferramenta grub-mkconfig para gerar /boot/grub/grub.cfg
:
# grub-mkconfig -o /boot/grub/grub.cfg
Por padrão, os scripts de geração adicionam automaticamente entradas de menu para todos os kernels do Arch Linux instalados na configuração gerada.
- Depois de instalar ou remover um kernel, você só precisa executar novamente o comando acima, o grub-mkconfig.
- Para obter dicas sobre o gerenciamento de várias entradas do GRUB, por exemplo, ao usar os kernels linux e linux-lts, consulte GRUB/Tips and tricks#Multiple entries.
Para adicionar automaticamente entradas para outros sistemas operacionais instalados, consulte #Detectando outros sistemas operacionais.
Você pode adicionar entradas adicionais ao menu editando /etc/grub.d/40_custom
e regerando /boot/grub/grub.cfg
. Ou você pode criar /boot/grub/custom.cfg
e adicioná-las lá. Alterações no /boot/grub/custom.cfg
não requerem reexecução do grub-mkconfig, já que /etc/grub.d/41_custom
adiciona a declaração source
para o arquivo de configuração gerado.
/etc/grub.d/40_custom
pode ser usado como um modelo para criar /etc/grub.d/nn_custom
, sendo que nn
define a precedência, indicando a ordem em que o script é executado. Os scripts de ordem são executados e determinam o posicionamento no menu de inicialização do GRUB. nn
deve ser maior que 06
para garantir que os scripts necessários sejam executados primeiro.Veja #Exemplos de entrada de menu de boot para mais exemplos de entradas de menu personalizadas.
Detectando outros sistemas operacionais
Para fazer com que o grub-mkconfig procure por outros sistemas instalados e adicioná-los automaticamente ao menu, instale o pacote os-prober e monte as partições das quais outros outros sistemas inicializam. Então, execute novamente o grub-mkconfig. Se você receber a seguinte saída: Warning: os-prober will not be executed to detect other bootable partitions
então edite /etc/default/grub
e adicione/descomente:
GRUB_DISABLE_OS_PROBER=false
E tente novamente.
- O ponto de montagem exato não importa, pois os-prover lê o
mtab
para identificar lugares para pesquisar por entradas inicializáveis. - Lembre-se de montar as partições toda vez que você executar grub-mkconfig para incluir os outros sistemas operacionais.
Windows
Para o Windows instalado no modo UEFI, certifique-se de que a partição de sistema EFI contendo o Windows Boot Manager (bootmgfw.efi
) esteja montada. Execute os-prober
como root para detectar e gerar uma entrada para ele.
Para Windows instalado no modo BIOS, monte a partição de sistema do Windows (seu rótulo do sistema de arquivos deve ser System Reserved
ou SYSTEM
). Execute os-prober
como root para detectar e gerar uma entrada para ele.
- As partições NTFS nem sempre podem ser detectadas quando montadas com os drivers padrão do Linux. Se o GRUB não estiver detectando, tente instalar o NTFS-3G e remontá-las.
- Partições encriptadas do Windows podem precisar ser descriptografadas antes da montagem. Para o BitLocker, isso pode ser feito com cryptsetup (Português) ou dislockerAUR. Isso deve ser suficiente para o os-prober adicionar a entrada correta.
Argumentos adicionais
Para passar argumentos adicionais personalizados para a imagem do Linux, você pode definir as variáveis GRUB_CMDLINE_LINUX
e GRUB_CMDLINE_LINUX_DEFAULT
em /etc/default/grub
. As duas são anexadas uma à outra e passadas ao kernel ao gerar entradas de inicialização comuns. Para a entrada de inicialização de recuperação, apenas GRUB_CMDLINE_LINUX
é usado na geração.
Não é necessário usar ambos, mas pode ser útil. Por exemplo, você poderia usar GRUB_CMDLINE_LINUX_DEFAULT="resume=UUID=uuid-da-partição-swap quiet"
, sendo uuid-da-partição-swap
o UUID da sua partição swap para permitir a continuação após hibernação. Isso geraria uma entrada de inicialização de recuperação sem o resumo e sem quiet
para suprimir mensagens do kernel durante uma inicialização a partir dessa entrada de menu. Porém, as outras entradas de menu (comuns) os teriam como opções.
Por padrão, o grub-mkconfig determina o UUID do sistema de arquivos raiz para a configuração. Para desabilitar isso, descomente GRUB_DISABLE_LINUX_UUID=true
.
Para gerar a entrada de recuperação do GRUB, você precisa garantir que GRUB_DISABLE_RECOVERY
não esteja definido como true
em /etc/default/grub
.
Veja Parâmetros do kernel para mais informações.
LVM
Se você usa LVM para sua partição /boot
ou /
, certifique-se de que o módulo lvm
esteja pré-carregado:
/etc/default/grub
GRUB_PRELOAD_MODULES="... lvm"
RAID
O GRUB fornece um manuseio conveniente de volumes RAID. Você precisa carregar os módulos GRUB mdraid09
ou mdraid1x
para permitir que você aborde o volume nativamente:
/etc/default/grub
GRUB_PRELOAD_MODULES="... mdraid09 mdraid1x"
Por exemplo, /dev/md0
se torna:
set root=(md/0)
sendo que um volume RAID particionado (p.ex., /dev/md0p1
) se torna:
set root=(md/0,1)
Para instalar o grub ao usar o RAID1 como partição /boot
(ou usando /boot
alojado em uma partição raiz RAID1), nos sistemas BIOS, simplesmente execute o grub-install em ambas as unidades, como:
# grub-install --target=i386-pc --debug /dev/sda # grub-install --target=i386-pc --debug /dev/sdb
sendo que o vetor RAID 1 contendo /boot
está contido em ambos /dev/sda
e /dev/sdb
.
/boot criptografado
O GRUB também tem suporte especial para inicializar com um /boot
criptografado. Isto é feito desbloqueando um dispositivo de bloco LUKS para ler sua configuração e carregar qualquer initramfs e kernel dele. Esta opção tenta resolver o problema de ter uma partição de inicialização não criptografada.
/boot
não precisa obrigatoriamente ser mantido em uma partição separada; ele também pode ficar sob a árvore de diretórios /
da raiz do sistema.Para ativar este recurso, criptografe a partição com /boot
que reside nela usando LUKS normalmente. Em seguida, adicione a seguinte opção para /etc/default/grub
:
/etc/default/grub
GRUB_ENABLE_CRYPTODISK=y
Esta opção é usada pelo grub-install para gerar o grub core.img
.
Certifique-se de instalar o grub depois de modificar esta opção ou criptografar a partição.
Sem mais alterações, você será solicitado duas vezes a informar uma senha: o primeiro para o GRUB desbloquear o ponto de montagem /boot
na inicialização, o segundo para desbloquear o sistema de arquivos raiz como implementado pelo initramfs. Você pode usar um initramfs para evitar isso.
- Se você quiser gerar o arquivo de configuração principal, certifique-se de que
/boot
esteja montado. - Para realizar atualizações do sistema envolvendo o ponto de montagem
/boot
, certifique-se de que o/boot
criptografado esteja desbloqueado e montado antes de executar uma atualização. Com uma partição/boot
separada, isso pode ser feito automaticamente na inicialização usando o crypttab com uma keyfile.
- Se você usar um mapa de teclado especial, uma instalação padrão do GRUB não o saberá. Isso é relevante para saber como inserir a frase secreta para desbloquear o dispositivo de bloco LUKS. Consulte GRUB/Tips and tricks#Manual configuration of core image for early boot.
- Se você tiver problemas para obter a solicitação de uma senha (erros relacionados a cryptouuid, cryptodisk ou "dispositivo não encontrado"), tente reinstalar o GRUB e acrescentar
--modules="part_gpt part_msdos"
ao final do seu comandogrub-install
.
/boot
quando as atualizações precisarem acessar arquivos relacionados.LUKS2
GRUB 2.06 tem suporte limitado ao LUKS2. Veja GRUB bug #55093.
- Argon2id (padrão do cryptsetup) e Argon2i PBKDFs não são suportados (GRUB bug #59409), somente PBKDF2 é.
grub-install
não oferece suporte a criar uma imagem core que pudesse ser usada para desbloquear LUKS2. Veja os comentários abaixo ou em grub-gitAUR para uma solução de contorno.
Use grub-install
conforme descrito na seção #Instalação. Porém, o binário EFI gerado não oferece suporte a LUKS2 e precisa ser substituído.
Crie /boot/grub/grub-pre.cfg
. Substitua UUID
pela saída de lsblk -dno UUID /dev/nvme0n1p2 | tr -d -
. Use lvm/NomeDoGrupoDoVolume-NomeDoVolumeLógico
em vez de crypto0
se sua unidade raiz estiver em um volume lógico LVM dentro do volume LUKS.
/boot/grub/grub-pre.cfg
set crypto_uuid=UUID cryptomount -u $crypto_uuid set root=crypto0 set prefix=($root)/boot/grub insmod normal normal
Adicione lvm
se você usa LVM. Substitua ext2
por btrfs
ou outro módulo de sistema de arquivos, se necessário. Substitua gcry_sha256
por gcry_sha512
ou gcry_whirlpool
se for necessário:
$ grub-mkimage -p /boot/grub -O x86_64-efi -c grub-pre.cfg -o /tmp/grubx64.efi luks2 part_gpt cryptodisk gcry_rijndael pbkdf2 gcry_sha256 ext2
Copie à ESP:
# install -v /tmp/grubx64.efi esp/EFI/GRUB/grubx64.efi
Se você inserir uma senha inválida durante a inicialização e terminar no shell de recuperação do GRUB, tente cryptomount -a
para montar todas (espera-se que apenas uma) partições criptografadas ou use cryptomount -u $crypto_uuid
para montar uma específica. Em seguida, prossiga com insmod normal
e normal
como de costume.
Se você inserir uma senha correta, mas um erro Invalid passphrase
for retornado imediatamente, certifique-se de que os módulos criptográficos corretos sejam especificados. Use cryptsetup luksDump /dev/nvme0n1p2
e verifique se a função hash (SHA-256, SHA-512) corresponde aos módulos (gcry_sha256
, gcry_sha512
) instalados e o algoritmo PBKDF seja pbkdf2. O hash e o algoritmos de PBDKDF podem ser alterados para chaves existentes usando cryptsetup luksConvertKey --hash sha256 --pbkdf pbkdf2 /dev/nvme0n1p2
. Em circunstâncias normais, deve levar alguns segundos antes que a senha seja processada.
grub.cfg personalizado
Esta seção descreve a criação manual de entradas de inicialização do GRUB em /boot/grub/grub.cfg
em vez de confiar em grub-mkconfig.
Um arquivo de configuração básico do GRUB usa as seguintes opções:
(hdX,Y)
é a partição Y no disco X, números de partição iniciando em 1, números de disco iniciando em 0set default=N
é a entrada de inicialização padrão que é escolhida após atingido um tempo limite para ação do usuárioset timeout=M
é o tempo M para aguardar em segundos para uma seleção de usuário antes da padrão ser inicializadamenuentry "título" {opções desta entrada}
é uma entrada padrão chamadatítulo
set root=(hdX,Y)
define a partição de inicialização, onde os módulos de kernel e GRUB estão armazenados (o boot não precisa estar em uma partição separada e pode simplesmente ser um diretório sob a partição "root" (/
)
/boot/grub/grub.cfg
gerado pelo "grub-mkconfig". Adicione-os a /etc/grub.d/40_custom
e gere novamente o arquivo de configuração principal ou adicione-os a /boot/grub/custom.cfg
.Para obter dicas sobre o gerenciamento de várias entradas do GRUB, por exemplo, ao usar os kernels linux e linux-lts, consulte GRUB/Tips and tricks#Multiple entries.
Para entradas de menu de inicialização de Archiso e Archboot, veja Multiboot USB drive#Boot entries.
Comandos do GRUB
menuentry "Desligamento do sistema" { echo "Desligando o sistema..." halt }
menuentry "Reinicialização do sistema" { echo "Reinicializando o sistema..." reboot }
if [ ${grub_platform} == "efi" ]; then menuentry 'Configuração do firmware UEFI' --id 'uefi-firmware' { fwsetup } fi
Binarios de EFI
Ao iniciar o modo UEFI, o GRUB pode carregar outros binários EFI.
if
:
if [ ${grub_platform} == "efi" ]; then coloque apenas entradas de menu UEFI aqui fi
Shell de UEFI
Você pode iniciar o UEFI Shell colocando-a na raiz da partição de sistema EFI e adicionando esta entrada de menu:
menuentry "UEFI Shell" { insmod fat insmod chain search --no-floppy --set=root --file /shellx64.efi chainloader /shellx64.efi }
gdisk
Baixe o aplicativo EFI gdisk e copie gdisk_x64.efi
para esp/EFI/tools/
.
menuentry "gdisk" { insmod fat insmod chain search --no-floppy --set=root --file /EFI/tools/gdisk_x64.efi chainloader /EFI/tools/gdisk_x64.efi }
Carregando uma imagem de kernel unificada
Se você tiver uma imagem de kernel unificada gerada a partir de Secure Boot ou outro meio, você pode adicioná-lo ao menu de inicialização. Por exemplo:
menuentry "Arch Linux" { insmod fat insmod chain search --no-floppy --set=root --fs-uuid UUID_DO_SISTEMA_DE_ARQUIVOS chainloader /EFI/Linux/Arch-linux.efi }
Dual boot
GNU/Linux
Presumindo que outra distribuição esteja na partição sda2
:
menuentry "Outro Linux" { set root=(hd0,2) linux /boot/vmlinuz (adicione outras opções aqui conforme necessário) initrd /boot/initrd.img (se outro kernel usa/precisa de um) }
Alternativamente, permita o GRUB pesquisar a partição correta pelo UUID ou label do sistema de arquivos:
menuentry "Outro Linux" { # presumindo que o UUID seja 763A-9CB6 search --no-floppy --set=root --fs-uuid 763A-9CB6 # pesquise pelo rótulo OUTRO_LINUX (certifique-se que o rótulo da partição não seja ambígua) #search --no-floppy --set=root --label OUTRO_LINUX linux /boot/vmlinuz (adicione aqui outras opções necessárias, por exemplo: root=UUID=763A-9CB6) initrd /boot/initrd.img (se outro kernel usa/precisa de um) }
Se a outra distribuição já tiver uma pasta /boot
válida com o GRUB instalado, grub.cfg
, kernel e initramfs, o GRUB poderá ser instruído a carregar esses outros arquivos de grub.cfg
dinamicamente durante a inicialização. Por exemplo, para hd0
e a quarta partição GPT:
menuentry "configfile hd0,gpt4" { insmod part_gpt insmod btrfs insmod ext2 set root='hd0,gpt4' configfile /boot/grub/grub.cfg }
Ao escolher esta entrada, o GRUB carrega o arquivo grub.cfg
do outro volume e exibe esse menu. Quaisquer alterações na variável de ambiente feitas pelos comandos no arquivo não serão preservadas após o retorno do configfile
. Pressione Esc
para retornar ao primeiro menu do GRUB.
Windows instalado em modo UEFI/GPT
Este modo determina onde o carregador de boot do Windows reside e carrega-o após o GRUB quando a entrada do menu é selecionada. A principal tarefa aqui é encontrar a partição do sistema EFI e executar o carregador de boot a partir dela.
if [ "${grub_platform}" == "efi" ]; then menuentry "Microsoft Windows Vista/7/8/8.1 UEFI/GPT" { insmod part_gpt insmod fat insmod chain search --no-floppy --fs-uuid --set=root $hints_string $fs_uuid chainloader /EFI/Microsoft/Boot/bootmgfw.efi } fi
sendo que $hints_string
e $fs_uuid
são obtidas com os dois comandos abaixo.
O comando $fs_uuid
determina o UUID da partição de sistema EFI:
# grub-probe --target=fs_uuid esp/EFI/Microsoft/Boot/bootmgfw.efi
1ce5-7f28
Como alternativa, é possível executar lsblk --fs
e ler o UUID da partição do sistema EFI a partir dele.
O comando $hints_string
determinará a localização da partição do sistema EFI, neste caso o disco rígido 0:
# grub-probe --target=hints_string esp/EFI/Microsoft/Boot/bootmgfw.efi
--hint-bios=hd0,gpt1 --hint-efi=hd0,gpt1 --hint-baremetal=ahci0,gpt1
Estes dois comandos presumem o uso da ESP do Windows montada em esp
. Pode haver diferenças entre maiúsculas e minúsculas no caminho para o arquivo EFI do Windows, com o Windows e tudo mais.
Windows instalado em modo BIOS/MBR
bootmgr
diretamente e fazer carregamento em cadeia (chainloading) do setor de inicialização da partição não é mais necessário para inicializar Windows em uma configuração de BIOS/MBR./bootmgr
, não sua partição Windows "real" (geralmente C:
). O rótulo do sistema de arquivos da partição do sistema é Sistema Reservado
ou SISTEMA
e a partição tem por volta de 100 para 549 MiB em tamanho. Veja Wikipedia:System partition and boot partition para mais informações.Ao longo desta seção, presume-se que sua partição do Windows é /dev/sda1
. Uma partição diferente mudará todas as instâncias de hd0,msdos1
.
Em ambos exemplos XXXXXXXXXXXXXXXX
é o UUID do sistema de arquivos que pode ser encontrado com o comando lsblk --fs
.
Para Windows Vista/7/8/8.1/10:
if [ "${grub_platform}" == "pc" ]; then menuentry "Microsoft Windows Vista/7/8/8.1/10 BIOS/MBR" { insmod part_msdos insmod ntfs insmod ntldr search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1 XXXXXXXXXXXXXXXX ntldr /bootmgr } fi
Para Windows XP:
if [ "${grub_platform}" == "pc" ]; then menuentry "Microsoft Windows XP" { insmod part_msdos insmod ntfs insmod ntldr search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1 XXXXXXXXXXXXXXXX ntldr /ntldr } fi
\boot\bcd
(código de erro 0xc000000f
). Você pode consertá-lo indo até o Console de Recuperação do Windows (cmd.exe
do disco de instalação) e executando:
X:\> bootrec.exe /fixboot X:\> bootrec.exe /RebuildBcd
Não use bootrec.exe /Fixmbr
porque ele apagará o GRUB.
Ou você pode usar a função "Reparo de inicialização" no menu "Solução de problemas" - isso não eliminará o GRUB, mas consertará a maioria dos erros.
Além disso, é melhor você ficar conectado tanto no disco rígido de destino quanto no dispositivo inicializável SOMENTE. O Windows geralmente não conserta as informações de inicialização se algum outro dispositivo estiver conectado.
Usando rótulos
É possível usar rótulos do sistema de arquivos, nomes legíveis anexados ao sistemas de arquivos, ao usar a opção --label
no search
. Primeiramente, tenha certeza de que seu sistema de arquivos tem um rótulo.
Então, adicione uma entrada usando rótulos. Um exemplo disso:
menuentry "Arch Linux, sessão texto" { search --label --set=root archroot linux /boot/vmlinuz-linux root=/dev/disk/by-label/archroot ro initrd /boot/initramfs-linux.img }
Usando o shell de comandos
Como o MBR é muito pequeno para armazenar todos os módulos do GRUB, apenas o menu e alguns comandos básicos residem nele. A maior parte da funcionalidade do GRUB permanece nos módulos em /boot/grub/
, que são inseridos conforme necessário. Em condições de erro (por exemplo, se o layout da partição for alterado), o GRUB poderá falhar na inicialização. Quando isso acontece, um shell de comando pode aparecer.
O GRUB oferece vários shells/prompts. Se houver um problema ao ler o menu, mas o gerenciador de inicialização conseguir localizar o disco, você provavelmente será descartado no shell "normal":
grub>
Se houver um problema mais sério (por exemplo, o GRUB não conseguir localizar os arquivos necessários), você poderá ser direcionado para o shell "rescue":
grub rescue>
O shell de recuperação é um subconjunto restrito do shell normal, oferecendo muito menos funcionalidade. Se for jogado no shell de recuperação, primeiro tente inserir o módulo "normal" e, em seguida, inicie o shell "normal":
grub rescue> set prefix=(hdX,Y)/boot/grub grub rescue> insmod (hdX,Y)/boot/grub/i386-pc/normal.mod rescue:grub> normal
Suporte a paginador
O GRUB possui suporte a paginador para ler comandos que fornecem saída longa (como o comando help
). Isso funciona apenas no modo shell normal e não no modo de recuperação. Para digitar o paginador, digite no shell de comando do GRUB:
sh:grub> set pager=1
Usando o ambiente shell de comandos para iniciar sistemas operacionais
grub>
O ambiente de shell de comando do GRUB pode ser usado para inicializar sistemas operacionais. Um cenário comum pode ser inicializar o Windows/Linux armazenado em uma unidade/partição via carregamento em cadeia (chainloading).
Chainloading significa carregar outro carregador de boot a partir do atual, isto é, carregamento em cadeia.
O outro gerenciador de boot pode ser incorporado no início de um disco particionado (MBR), no início de uma partição ou em um disco sem partição (VBR) ou como um binário EFI no caso de UEFI.
Carregando o VBR de uma partição
set root=(hdX,Y) chainloader +1 boot
X=0,1,2... Y=1,2,3...
Por exemplo, para carregar o Windows armazenado na primeira partição do primeiro disco rígido,
set root=(hd0,1) chainloader +1 boot
Da mesma forma, o GRUB instalado em uma partição pode ser carregado em cadeia.
Carregando o MBR de um disco ou o VBR de um disco sem partição
set root=hdX chainloader +1 boot
Carregando Windows/Linux instalado em modo UEFI
insmod fat set root=(hd0,gpt4) chainloader (${root})/EFI/Microsoft/Boot/bootmgfw.efi boot
insmod fat
é usado para carregar o módulo do sistema de arquivos FAT para acessar o gerenciador de boot do Windows na partição do sistema EFI.
(hd0,gpt4)
ou /dev/sda4
é a partição do sistema EFI neste exemplo.
A entrada na linha chainloader
especifica o caminho do arquivo .efi a ser carregado em cadeia.
Carregamento normal
Veja os exemplos em #Usando o console de recuperação
Usando o console de recuperação
Veja #Usando o shell de comandos primeiro. Se não for possível ativar o shell padrão, uma solução possível é inicializar usando um live CD ou algum outro disco de recuperação para corrigir erros de configuração e reinstalar o GRUB. No entanto, esse disco de inicialização nem sempre está disponível (nem necessário); o console de recuperação é surpreendentemente robusto.
Os comandos disponíveis na recuperação do GRUB incluem insmod
, ls
, set
e unset
. Este exemplo usa set
e insmod
. set
modifica variáveis e insmod
insere novos módulos para adicionar funcionalidade.
Antes de iniciar, o usuário deve saber a localização de sua partição /boot
(seja uma partição separada ou um subdiretório sob sua raiz):
grub rescue> set prefix=(hdX,Y)/boot/grub
sendo X
o número da unidade física e Y
o número da partição.
/boot
do caminho (por exemplo, digite set prefix=(hdX,Y)/grub
).Para expandir as capacidades do console, insira o módulo linux
:
grub rescue> insmod i386-pc/linux.mod
ou simplesmente
grub rescue> insmod linux
Isso introduz os comandos linux
e initrd
, que devem ser familiares.
Um exemplo, inicializando o Arch Linux:
set root=(hd0,5) linux /boot/vmlinuz-linux root=/dev/sda5 initrd /boot/initramfs-linux.img boot
Com uma partição de inicialização separada (por exemplo, ao usar UEFI), altere as linhas novamente:
set root=(hd0,5) linux (hdX,Y)/vmlinuz-linux root=/dev/sda6 initrd (hdX,Y)/initramfs-linux.img boot
error: fim prematuro do arquivo /NOME_DO_SEU_KERNEL
durante a execução do comando linux
, você pode tentar linux16
.Após inicializar com êxito a instalação do Arch Linux, os usuários podem corrigir o grub.cfg
conforme necessário e reinstalar o GRUB.
Para reinstalar o GRUB e corrigir o problema completamente, altere /dev/sda
, se necessário. Veja #Instalação para detalhes.
Remoção do GRUB
Em geral, para remover o grub, deve-se fazer as etapas de instalação na ordem inversa. Talvez limpando qualquer sobra no final. No entanto, antes de fazer qualquer coisa, é preciso decidir se e como a máquina inicializará após a remoção. Supondo que alguém remova o grub porque gostaria de usar outro carregador de inicialização, um método seguro, embora um pouco difícil, é certificar-se de que o outro gerenciador de boot está funcionando antes de remover o grub.
De qualquer forma, mesmo ao remover o grub antes de instalar outro gerenciador de boot, para o caso UEFI, execute:
$ efibootmgr
E verifique se o outro gerenciador de boot está listado na linha BootOrder
. Se o grub não foi removido, o outro gerenciador de boot deve ser listado antes de grub. Se grub já foi removido, grub não deve ser mencionado nessa linha. Mas observe que esta é apenas uma condição necessária, mas não suficiente, para que a máquina inicialize com o outro gerenciador de boot. Nem é uma condição suficiente para a remoção completa do grub.
Para máquinas UEFI e não UEFI, grub-install
foi executado manualmente como parte da instalação do grub. Um de seus trabalhos para o caso UEFI foi executar o equivalente a efibootmgr --create
. Como parte da remoção do grub, deve-se remover os produtos de grub-install
. O oposto de efibootmgr --create
é efibootmgr --delete-bootnum
, ou um programa equivalente. Uma maneira de obter o número da entrada de inicialização para o comando efibootmgr --delete-bootnum
é a partir da saída de efibootmgr
(sem argumentos).
grub-install
cria o diretório /boot/grub
que precisa ser removido manualmente. Embora alguns usuários queiram mantê-lo, caso queiram instalar o grub novamente.
Após migrar para o GPT/UEFI, pode-se querer remover o código de inicialização do MBR usando dd:
# dd if=/dev/zero of=/dev/sdX bs=440 count=1
Solução de problemas
Sistemas de arquivos sem suporte
No caso do GRUB não possuir suporte ao sistema de arquivos raiz, uma partição /boot
alternativa com um sistema de arquivos compatível deve ser criada. Em alguns casos, a versão de desenvolvimento do GRUB grub-gitAUR pode ter suporte nativo para o sistema de arquivos.
Se o GRUB é usado com um sistema de arquivos incompatível, ele não é capaz de extrair o UUID da sua unidade, então ele usa nomes clássicos não-persistentes /dev/sdXx
. Nesse caso, você pode ter que editar manualmente /boot/grub/grub.cfg
e substituir root=/dev/sdXx
com root=UUID=XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
. Você pode usar o comando blkid
para obter o UUID do seu dispositivo, consulte Nomeação persistente de dispositivo de bloco.
Embora o GRUB ofereça suporte a F2FS desde a versão 2.0.4, ele não pode ler corretamente seus arquivos de inicialização de uma partição F2FS que foi criada com o sinalizador extra_attr
ativado.
Habilitar mensagens de depuração
Adicionar:
set pager=1 set debug=all
para grub.cfg
.
Mensagem de erro sobre estilo msdos
grub-setup: warn: Este rótulo de partição estilo msdos não tem espaço vago pós-MBR; não será possível embuti-lo! grub-setup: warn: Incorporação não permitida. O GRUB só pode ser instalado neste setup usando blocklists. Porém. blocklists são INSTÁVEIS e seu uso não é aconselhado. grub-setup: error: If you really want blocklists, use --force.
Este erro pode ocorrer quando você tenta instalar o GRUB em um contêiner VMware. Leia mais sobre isso aqui. Isso acontece quando a primeira partição começa logo após o MBR (bloco 63), sem o espaço usual de 1 MiB (2048 blocos) antes da primeira partição. Leia #Instruções específicas de Master Boot Record (MBR).
UEFI
Erros comuns de instalação
- Se você tiver um problema ao executar o grub-install com sysfs ou procfs e ele disser que você deve executar
modprobe efivarfs
, tente Unified Extensible Firmware Interface#Mount efivarfs. - Sem a opção
--target
ou--directory
, o grub-install não pode determinar qual firmware deve ser instalado. Em tais casos,grub-install
irá imprimirsource_dir não existe. Por favor, especifique --target ou --diretório
. - Se, depois de executar o grub-install, for informado que sua partição não se parece com uma partição EFI, a partição provavelmente não é
Fat32
.
Criar uma entrada do GRUB no gerenciador de boot do firmware
grub-install
automaticamente tenta criar uma entrada no gerenciador de boot. Se não conseguir, então veja UEFI#efibootmgr para instruções de como usar o efibootmgr
para criar uma entrada. No entanto, o problema possivelmente é devido a não ter inicializado o seu CD/USB no modo UEFI, como descrito em UEFI#Create UEFI bootable USB from ISO.
Como outro exemplo de criação de uma entrada GRUB no gerenciador de boot do firmware, considere efibootmgr -c
. Isso pressupõe que /dev/sda1 é a partição de sistema EFI e está montada em /boot/efi. Quais são o comportamento padrão de efibootmgr
. Ele cria uma nova opção de inicialização chamada "Linux" e a coloca no topo da lista de ordem de inicialização. Opções podem ser passadas para modificar o comportamento padrão. O carregador de sistema operacional padrão é \EFI\arch\grub.efi.
Descartar o shell de recuperação
Se o GRUB for carregado, mas cair no shell de recuperação sem erros, pode ser devido a um destes dois motivos:
- Pode ser por causa de um
grub.cfg
ausente ou extraviado. Isso acontecerá se o UEFI do GRUB tiver sido instalado com--boot-directory
egrub.cfg
estiver faltando, - Isso também acontece se a partição de inicialização, que é codificada no arquivo
grubx64.efi
, for alterada.
UEFI do GRUB não carregado
Um exemplo de um UEFI funcional:
# efibootmgr -v
BootCurrent: 0000 Timeout: 3 seconds BootOrder: 0000,0001,0002 Boot0000* GRUB HD(1,800,32000,23532fbb-1bfa-4e46-851a-b494bfe9478c)File(\EFI\GRUB\grubx64.efi) Boot0001* Shell HD(1,800,32000,23532fbb-1bfa-4e46-851a-b494bfe9478c)File(\shellx64.efi) Boot0002* Festplatte BIOS(2,0,00)P0: SAMSUNG HD204UI
Se a tela ficar preta por um segundo e a próxima opção de inicialização for tentada posteriormente, de acordo com esta publicação, mova o GRUB para a raiz da partição pode ajudar. A opção de inicialização deve ser excluída e recriada posteriormente. A entrada para o GRUB deve ficar assim:
Boot0000* GRUB HD(1,800,32000,23532fbb-1bfa-4e46-851a-b494bfe9478c)File(\grubx64.efi)
Caminho de inicialização padrão/reserva
Alguns firmwares UEFI exigem um arquivo inicializável em um local conhecido antes de mostrar as entradas de inicialização da UEFI NVRAM. Se este for o caso, grub-install
irá reivindicar que efibootmgr
adicionou uma entrada para inicializar o GRUB, no entanto a entrada não será mostrada no seletor de ordem de inicialização do VisualBIOS. A solução é instalar o GRUB no caminho de inicialização padrão/reserva:
# grub-install --target=x86_64-efi --efi-directory=esp --removable
Alternativamente, você pode mover um executável do GRUB EFI já instalado para o caminho padrão/reserva:
# mv esp/EFI/grub esp/EFI/BOOT # mv esp/EFI/BOOT/grubx64.efi esp/EFI/BOOT/BOOTX64.EFI
Assinatura inválida
Se tentar inicializar o Windows, resulta em um erro de "assinatura inválida", por exemplo, depois de reconfigurar partições ou adicionar discos rígidos adicionais, (re)mova a configuração do dispositivo do GRUB e reconfigure:
# mv /boot/grub/device.map /boot/grub/device.map-old # grub-mkconfig -o /boot/grub/grub.cfg
grub-mkconfig
agora deve mencionar todas as opções de inicialização encontradas, incluindo o Windows. Se funcionar, remova /boot/grub/device.map-old
.
Inicialização congelando
Se a inicialização for travada sem nenhuma mensagem de erro após o GRUB carregar o kernel e o disco em memória inicial, tente remover o parâmetro do kernel add_efi_memmap
.
Arch não encontrado por outros sistemas operacionais
Algumas pessoas relataram que outras distribuições podem ter problemas para encontrar o Arch Linux automaticamente com os-prober
. Se esse problema ocorrer, foi relatado que a detecção pode ser melhorada com a presença de /etc/lsb-release
. Esta ferramenta de arquivo e atualização está disponível com o pacote lsb-release.
Aviso ao instalar em chroot
Ao instalar o GRUB em um sistema LVM em um ambiente chroot (por exemplo, durante a instalação do sistema), você pode receber avisos como
/run/lvm/lvmetad.socket: connect failed: No such file or directory
ou
WARNING: failed to connect to lvmetad: No such file or directory. Falling back to internal scanning.
Isto é porque /run
não está disponível dentro do chroot. Esses avisos não impedem o sistema de inicializar, desde que tudo tenha sido feito corretamente, assim você pode continuar com a instalação.
GRUB carrega lentamente
O GRUB pode levar muito tempo para carregar quando o espaço em disco está baixo. Verifique se você tem espaço livre em disco suficiente em sua partição /boot
ou /
quando tiver problemas.
erro: sistema de arquivos desconhecido
O GRUB pode emitir erro: sistema de arquivos desconhecido
e se recusar a inicializar por alguns motivos. Se você tem certeza de que todos os UUIDs estão corretos e todos os sistemas de arquivos são válidos e compatíveis, pode ser que sua partição de inicialização de BIOS esteja localizada fora dos primeiros 2 TiB da unidade [1]. Use uma ferramenta de particionamento de sua escolha para garantir que essa partição esteja totalmente localizada nos primeiros 2 TiB, depois reinstale e reconfigure o GRUB.
Esse erro também pode ser causado por um sistema de arquivos ext4 tem um conjuto de recursos sem suporte:
large_dir
-- sem suporte.metadata_csum_seed
-- terá suporte no GRUB 2.11 (commit).
/boot
.grub-reboot não está redefinido
O GRUB parece não conseguir gravar em partições BTRFS de raiz [2]. Se você usar o grub-reboot para inicializar em outra entrada, será incapaz de atualizar seu ambiente em disco. Execute o grub-reboot a partir da outra entrada (por exemplo, ao alternar entre várias distribuições) ou considere um sistema de arquivos diferente. Você pode redefinir uma entrada "sticky" executando grub-editenv create
e configurando GRUB_DEFAULT=0
no /etc/default/grub
(não esqueça grub-mkconfig -o /boot/grub/grub.cfg
).
BTRFS antigo impede a instalação
Se uma unidade estiver formatada com o BTRFS sem criar uma tabela de partição (por exemplo, /dev/sdx
), mais tarde será gravada a tabela de partições, existindo partes do formato BTRFS que persistem. A maioria dos utilitários e sistemas operacionais não vê isso, mas o GRUB se recusará a instalar, mesmo com --force
.
# grub-install: warning: Attempting to install GRUB to a disk with multiple partition labels. This is not supported yet. # grub-install: error: filesystem `btrfs' does not support blocklists.
Você pode zerar a unidade, mas a solução fácil que deixa seus dados sozinhos é apagar o superbloco BTRFS com wipefs -o 0x10040 /dev/sdx
.
Windows 8/10 não encontrado
Uma configuração no Windows 8/10 chamada "Hiberboot", "Hybrid Boot" or "Fast Boot" (inicialização rápida pode impedir que a partição do Windows seja montada, portanto, o grub-mkconfig
não localizará uma instalação do Windows. Desativar o Hiberboot no Windows permitirá que ele seja adicionado ao menu GRUB.
Recuperação do GRUB e /boot criptografado
Ao usar um /boot criptografado e você não conseguir inserir uma senha correta, você será jogado no prompt de recuperação do GRUB.
Este prompt de recuperação do grub tem capacidades limitadas. Use os seguintes comandos para completar a inicialização:
grub rescue> cryptomount <partição> grub rescue> insmod normal grub rescue> normal
Veja esta publicação de blog[link inativo 2023-04-23 ⓘ] para uma descrição melhor.
Verifique /etc/default/grub
se GRUB_TIMEOUT
está definido como 0
e, caso esteja, defina-o com um número positivo: ele define o número de segundos antes da entrada padrão do GRUB ser carregada. Verifique também se GRUB_TIMEOUT_STYLE
está definido como hidden
e defina como menu
, para que o menu seja exibido por padrão. Então gere novamente o arquivo principal e reinicie para verificar se funcionou.