AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 752459
Accepted
Guss
Guss
Asked: 2023-07-26 18:56:09 +0800 CST2023-07-26 18:56:09 +0800 CST 2023-07-26 18:56:09 +0800 CST

O computador inicializa no prompt do GRUB, depois de mover a unidade de um computador antigo

  • 772

Depois de obter um novo sistema, movi a unidade NVME do meu sistema antigo para o novo, onde ambas as máquinas estão configuradas para inicializar usando UEFI. Como a configuração EFI é específica da máquina, eu esperava encontrar problemas e vim preparado - inicializei a partir de um USB ao vivo, fiz a montagem e o chroot e reinstalei o GRUB de acordo com as instruções (encontradas em todos os lugares na web e repetidas abaixo), depois que uma reinicialização me leva ao prompt de comando do GRUB e não consigo descobrir como consertar isso - não importa o que eu faça, se eu selecionar a entrada de inicialização UEFI do Linux (conforme mostrado abaixo), recebo um prompt do grub. Se eu selecionar a entrada de inicialização UEFI do Windows (este é um sistema de inicialização dupla), ela carrega bem.

Sempre posso inicializar a instalação do Linux a partir do prompt do GRUB digitando configfile (hd0,gpt6)/@/boot/grub/grub.cfgque inicia o menu GRUB que eu esperava e a partir disso posso inicializar qualquer entrada sem problemas (estou usando o BTRFS como a partição raiz e /está no subvolume @- isso é bastante padrão para uma instalação do Ubuntu).

Aqui está a configuração atual:

# efibootmgr --verbose
BootCurrent: 0001
Timeout: 0 seconds
BootOrder: 0001,0005,0000,0002
Boot0000* UEFI Samsung SSD 970 EVO Plus 1TB S6P7NF0T423021F 1   HD(1,GPT,37b6d616-6865-44b1-a382-9987345e2cfa,0x800,0x32000)/File(\EFI\Boot\BootX64.efi)N.....YM....R,Y.
Boot0001* Neon  HD(1,GPT,37b6d616-6865-44b1-a382-9987345e2cfa,0x800,0x32000)/File(\EFI\Neon\shimx64.efi)
Boot0002* UEFI HTTPs Boot       PciRoot(0x0)/Pci(0x1f,0x6)/MAC(000000000000,0)/IPv4(0.0.0.00.0.0.0,0,0)/Uri()N.....YM....R,Y.
Boot0005* Windows Boot Manager  HD(1,GPT,37b6d616-6865-44b1-a382-9987345e2cfa,0x800,0x32000)/File(\EFI\Microsoft\Boot\bootmgfw.efi)WINDOWS.........x...B.C.D.O.B.J.E.C.T.=.{.9.d.e.a.8.6.2.c.-.5.c.d.d.-.4.e.7.0.-.a.c.c.1.-.f.3.2.b.3.4.4.d.4.7.9.5.}....................
# ll /boot/efi/EFI/
total 6
drwx------ 6 root root 1024 Jul 26 12:38 ./
drwx------ 4 root root 1024 Jan  1  1970 ../
drwx------ 2 root root 1024 Aug 28  2022 Boot/
drwx------ 5 root root 1024 Jul 26 12:38 Dell/
drwx------ 4 root root 1024 Aug 28  2022 Microsoft/
drwx------ 2 root root 1024 Jul 24 20:01 Neon/
# cat /boot/efi/EFI/Neon/grub.cfg 
search.fs_uuid 2886a665-f535-496e-a543-13c62983b0da root 
set prefix=($root)'/@/boot/grub'
configfile $prefix/grub.cfg
# ll /dev/disk/by-uuid/
total 0
drwxr-xr-x 2 root root 120 Jul 26 13:20 ./
drwxr-xr-x 9 root root 180 Jul 26 13:20 ../
lrwxrwxrwx 1 root root  15 Jul 26 13:20 2886a665-f535-496e-a543-13c62983b0da -> ../../nvme0n1p6
lrwxrwxrwx 1 root root  15 Jul 26 13:20 80D9-5688 -> ../../nvme0n1p1
lrwxrwxrwx 1 root root  15 Jul 26 13:20 82926928-1ed1-4a76-b0e8-d62a0171c1ee -> ../../nvme0n1p5
lrwxrwxrwx 1 root root  15 Jul 26 13:20 D8D6FA10D6F9EF1E -> ../../nvme0n1p4
# lsblk -e 7 -o name,fstype,size,fsused,label,partlabel,mountpoint,uuid,partuuid
NAME        FSTYPE      SIZE FSUSED LABEL PARTLABEL                    MOUNTPOINT            UUID                                 PARTUUID
nvme0n1               931.5G                                                                                                      
├─nvme0n1p1 vfat        100M  58.8M       EFI system partition         /boot/efi             80D9-5688                            37b6d616-6865-44b1-a382-9987345e2cfa
├─nvme0n1p2              16M              Microsoft reserved partition                                                            fdc1478a-852d-4f33-8e22-24a2ea209726
├─nvme0n1p3 BitLocker  50.2G              Basic data partition                                                                    e8584ca9-db86-4bb1-abf7-424afe77bc94
├─nvme0n1p4 ntfs        517M                                                                 D8D6FA10D6F9EF1E                     5373ade9-ed41-4164-85e2-c28b7026c25f
├─nvme0n1p5 swap       30.5G                                           [SWAP]                82926928-1ed1-4a76-b0e8-d62a0171c1ee d5d866a5-97d4-49bb-a182-6eec3abcba18
└─nvme0n1p6 btrfs     850.2G 440.5G linux                              /var/lib/docker/btrfs 2886a665-f535-496e-a543-13c62983b0da cb45a183-14d3-4a95-b89f-6b5e315609cd

Posso tentar reinstalar por:

  1. Remova a entrada de inicialização EFI ofensiva:efibootmgr -b 1 -B
  2. Reinstale o boot carregado no disco e EFI:grub-install /dev/nvme0n1 --target x86_64-efi --efi-directory /boot/efi/ --bootloader-id Neon
  3. Atualize a configuração do GRUB (não tenho certeza se é necessário, mas é o que dizem os documentos):update-grub2

Depois disso, a configuração parece que estou mostrando acima e, ao reiniciar, o GRUB não iniciará o menu automaticamente. Não tenho certeza sobre o UUID no dump EFI NVRAM, mas esse valor não está configurado em nenhum lugar que eu possa encontrar e é reproduzido se eu remover as entradas e recriá-las.

Alguma ideia do que estou perdendo?

boot
  • 1 1 respostas
  • 30 Views

1 respostas

  • Voted
  1. Best Answer
    Guss
    2023-07-27T18:09:25+08:002023-07-27T18:09:25+08:00

    TL;DR:

    ao usar o carregador de inicialização GRUB construído no Ubuntu, a entrada de inicialização UEFI DEVE ser nomeada ubuntu(ou pelo menos, o arquivo de configuração GRUB EFI deve estar em EFI/ubuntu/grub.cfg.

    Detalhes:

    O problema é com a configuração do GRUB em UEFI, inicialização segura (presumo) e como o Ubuntu configurou tudo isso: na inicialização do BIOS herdado, o BIOS inicializa um pequeno executável (512 bytes, acredito) que inicializa imediatamente outra coisa ( nos velhos tempos) ou encontra uma seção codificada no disco onde reside o restante do carregador de inicialização (um "carregador de inicialização de estágio 2"). Existem muitos problemas com essa configuração, o menor deles é que ela não pode funcionar com sistemas de arquivos avançados que movem as coisas, comprimem-nas etc. , você tinha que ter uma /bootpartição separada no ext2, onde residia o segundo estágio do GRUB.

    Com UEFI, há uma partição FAT32 (comparativamente) grande (o ESP) na qual o sistema operacional pode implantar grandes carregadores de inicialização e o firmware UEFI carregará todo o carregador de inicialização de uma só vez. A maneira como o Ubuntu usa esse recurso é implantar todo o carregador de inicialização GRUB como um único arquivo executável EFI chamado grubx64.efi. Este arquivo é executado pelo firmware UEFI - diretamente ou por meio de um shim (chamado shimx64.efi) para um sistema de inicialização segura somente da Microsoft CA. Esta instalação do GRUB sabe carregar um pequeno arquivo de configuração - grub.cfgda partição EFI que contém instruções sobre onde encontrar o arquivo de configuração completo. Como você tem o carregador de inicialização GRUB completo disponível imediatamente, pode ter drivers BTRFS ou ZFS que podem ler sistemas de arquivos avançados e não precisa de uma partição de inicialização separada.

    O problema é que todos esses caminhos de arquivo (até depois que o grub.cfgarquivo é carregado) são compilados no executável GRUB EFI e não são configuráveis ​​- e como tudo isso precisa ser assinado, você não pode atualizar essa configuração durante a instalação (a menos que você deseja configurar chaves pessoais no TPM da máquina e começar a recompilar os carregadores de inicialização). Como resultado, a instalação do Ubuntu GRUB (o que o KDE Neon, que é baseado no Ubuntu LTS, está usando) precisa do diretório do carregador de inicialização EFI - de onde é carregado - para ser , não pode ser outra coisa grub.cfgporque EFI/ubuntu/grub.cfgesse caminho foi compilado no grubx64.efiarquivo e se o arquivo de configuração não existir - você obtém o prompt do GRUB, como eu fiz.

    Podemos ver isso executando setno prompt do GRUB: a saída terá

    prefix=(hd0,gpt1)/EFI/ubuntu
    

    o que significa que o prefixo (de onde o GRUB pensa que foi carregado e de onde espera ver todos os outros arquivos) é codificado para o que o Ubuntu usa.

    Quando você instala o KDE Neon (que é o que estou usando), o instalador do Neon criará um EFI/ubuntue EFI/neonas instalações do carregador de boot - não sei por que eles tentam, já que a EFI/neonpasta nem é usada (provavelmente porque eles deseja que o nome da entrada do carregador de inicialização seja "neon" e, por algum motivo, isso significa que a pasta também deve ser chamada de "neon"? a especificação UEFI não exige isso), então funciona.

    O que fiz de errado foi presumir que a EFI/ubuntupasta era algum tipo de legado (instalei o Neon em cima de uma instalação anterior do Ubuntu) e removi (e também reinstalei o gerenciador de inicialização do Neon em EFI/Neon, porque queria que a entrada de inicialização fosse bem maiúscula) - então o executável do GRUB foi carregado (pelo firmware UEFI) da nova pasta, mas uma vez carregado - ele tentou encontrar o restante da configuração EFI/ubuntue não estava lá. Então, somos levados ao prompt para descobrir.

    • 0

relate perguntas

  • Por que `journalctl --list-boots` não corresponde ao relatório `uptime` e `who -b`?

  • Como iniciar um programa de console na inicialização (dentro de ../openbox/autostart)

  • Sistema intacto, grub quebrado

  • "pacman -Syu" 'provavelmente' quebrou meu sistema, porque a inicialização não foi montada

  • SSD clonado não inicializa e imprime linhas estranhas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve