web-dev-qa-db-ja.com

GRUB2の新しいメニューエントリ、「ファイルが見つかりません」および「最初にカーネルをロードする必要があります」エラー

GRUB2リストに新しいメニューエントリを追加したかったのです。これは私がこれと必要な情報をしようとした方法です:

GRUB2リストから「DebianWheezy」メニューエントリを選択した後のErros

error:file not found
error:you need to load the kernel first

/ etc/grub.d/12_debian

#!/bin/sh -e
cat << EOF
menuentry "Debian Wheezy" {
set root=(hd0,5)
linux /boot/vmlinuz-3.2.0-3-AMD64
initrd /boot/initrd.img-3.2.0-3-AMD64
}
EOF

ls/boot

config-3.2.0-3-AMD64  initrd.img-3.2.0-3-AMD64  vmlinuz-3.2.0-3-AMD64
grub                  System.map-3.2.0-3-AMD64

パーティショニング

sda1 - ntfs - Windows boot
sda2 - ntfs - Windows C:
sda3 - ntfs - Windows D:
sda4 - extended
-sda5 - ext4 - /boot
-sda6 - lvm - Debian testing
And inside sda6 there's LVM group calld G1 divided into volumes:
home, root, tmp, usr, var, swap

すべての設定に失敗したときに使用したソース

GRUB2命名規則

GRUB 2ブートローダー-Dedoimedo.comの完全なチュートリアル

どうしましたか?

編集#1

fdisk -l

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048      206847      102400    7  HPFS/NTFS/exFAT
/dev/sda2          206848    83473739    41633446    7  HPFS/NTFS/exFAT
/dev/sda3        83473799   935802314   426164258    7  HPFS/NTFS/exFAT
/dev/sda4       935802315   976771071    20484378+   f  W95 Ext'd (LBA)
/dev/sda5       935802880   936779775      488448   83  Linux
/dev/sda6       936781824   976771071    19994624   8e  Linux LVM

編集#2

グラブコンソール

linux /[TAB]
Possible files are:
lost+found/ bin/ share/ sbin/ lib/ include/ src/ games/ local/

set root=(hd0,msdos5)
linux/[TAB]
Possible files are:
lost+found/ config-3.2.0-3-AMD64 vmlinuz-3.2.0-3-AMD64 grub/ 
System.map-3.2.0-3-AMD64 initrd.img-3.2.0-3-AMD64

Grubコンソール、ブートテスト

set root=(hd0,msdos5)
linux /vmlinuz-3.2.0-3-AMD64 root=/dev/G1/root
initrd /initrd.img-3.2.0-3-AMD64
boot

#Many, many, many lines of text. After few seconds they stop. The most
#interesting i think are:

ALERT! /dev/G1/root does not exist. Dropping to a Shell!
/bin/sh: can't access tty; job control turned off

/ etc/grub.d/12_debian another try

#!/bin/sh -e
cat << EOF
menuentry "Debian Wheezy" {
insmod ext4
set root=(hd0,msdos5)
echo 'loading...'
linux /vmlinuz-3.2.0-3-AMD64
echo 'starting kernel...'
initrd /initrd.img-3.2.0-3-AMD64
}
EOF

結果:

error:file not found
loading...
starting kernel...

編集#3

/ boot/grub/grub.cfgの一部

### BEGIN /etc/grub.d/10_linux ###
menuentry 'Debian GNU/Linux, with Linux 3.2.0-3-AMD64' --class debian --    class gnu-linux --class gnu --class os {
    insmod gzio
    insmod lvm
    insmod part_msdos
    insmod ext2
    set root='(G1-root)'
    search --no-floppy --fs-uuid --set=root 94215fad-dcbe-4339-92be-f562b1b37133
    echo    'Loading Linux 3.2.0-3-AMD64 ...'
    linux   /boot/vmlinuz-3.2.0-3-AMD64 root=/dev/mapper/G1-root ro  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initrd.img-3.2.0-3-AMD64
}
### END /etc/grub.d/10_linux ###

/ etc/grub.d/12_debian next try

#!/bin/sh -e
cat << EOF
menuentry "Debian Wheezy" {
insmod ext4
set root=(hd0,msdos5)
echo 'loading...'
linux /vmlinuz-3.2.0-3-AMD64 root=/dev/mapper/G1-root
echo 'starting kernel...'
initrd /initrd.img-3.2.0-3-AMD64
}

結果

error:file not found
loading...
starting kernel...
2
r4czek

専用の/ bootパーティションがあるため(おそらく必要ありません)、そのパーティションには/ bootという名前のディレクトリがなく、ファイルが見つからないのはなぜですか。パスから/ bootを削除します。

1
psusi

うーん...古いスレッドですが、実際に答えが得られなかったようです。最近、同様の問題が発生しましたが、現在は修正されています。同様の問題を抱えている他の人には、変更することをお勧めします

set root='(hd0,msdos5)'

以下に

 search --no-floppy --fs-uuid --set=root '5bbd33b6-3333-3a33-3333-8045d333bb63'

ここで、1234-567Aは、から取得した目的のパーティションのUUIDです。

Sudo blkid /dev/sda5

その結果は次のようになります。

/dev/sda1: LABEL="SYSTEM" UUID="5bbd33b6-3333-3a33-3333-8045d333bb63" TYPE="ext4" PARTLABEL="EFI system partition" PARTUUID="0c33e3ab-d3dc-3af3-333d-a33eee3c333c"
0
R Schultz
menuentry "Debian Wheezy" {
insmod ext4
set root='(hd0,msdos5)'
echo 'loading ..'
linux /boot/vmlinuz-3.2.0-3-AMD64
echo 'starting kernel ...'
initrd /boot/initrd.img-3.2.0-3-AMD64
}
0
perilbrain