これは私の最初の質問で、Red Hatインストラクターにこの質問をしましたが、満足のいく答えが見つかりませんでした。
私はRHEL / CENTOS6、GRUB Legacy 0.97を使用しており、Linuxの起動プロセスを説明する多くのドキュメントを読んでいます。
ほとんどすべてのブログ、ドキュメントなどは関連する手順とプロセス全体を説明することに成功しますが、grub stage2がロードされたときに実際に発生することはすべて失敗します。
これはプロセスといくつかのテストの私の理解です。
- BIOS(EFIを無効にする)はMBRを読み取り、パーティションテーブルを見つけ、GRUB stage1(最初の446バイト)をメモリにロードします。
- 私の/bootパーティションは1024シリンダー未満であり、いくつかのドキュメントから私がインポートしたアイデアは、stage2が1024シリンダー未満の場合、GRUB stage1がstage2を直接ロードできることです。私が見たいくつかのドキュメントでは、stage1.5はMBRの次のセクタ63の前にあると述べ、他のドキュメントではディスクの最初の1MBのどこにでもあると言い、他のグループではstage1.5はGRUB v2にすぎないと主張しています。存在する。以前のバージョンのGRUBに適用可能です。
- GRUB stage2には、ファイルシステムを読み取り、カーネルとRAMディスクをロードし、コントロールをカーネルに渡すために必要なすべてのドライバ/モジュールがあります。
- カーネルはRHEL / CENTOS 6でinitを起動し、RHEL / CENTOS 7でsystemdを起動します。
ディスクの最初のMBにすべてのデータをダンプし、MBR以外には何もないことを確認できます。 446バイトのGRUB stage1がファイルシステムからstage2をどのようにロードするのか疑問に思います。ウィキペディアの一部の画像といくつかの文書によると、GRUBがインストールされている場合、stage1にはstage2を指すLBA48が含まれています。
実際には、/boot/grub/ディレクトリからstage2を削除するか名前を変更してシステムが起動するかどうかをテストしました。ファイルシステムにstage2がない場合でも、システムは起動を続行できます。
/dev/sdaの最初のMB
[root@chief zul.kifal]# dd if=/dev/sda bs=1024k count=1 | hexdump -C
00000000 eb 48 90 10 8e d0 bc 00 b0 b8 00 00 8e d8 8e c0 |.H..............|
00000010 fb be 00 7c bf 00 06 b9 00 02 f3 a4 ea 21 06 00 |...|.........!..|
00000020 00 be be 07 38 04 75 0b 83 c6 10 81 fe fe 07 75 |....8.u........u|
00000030 f3 eb 16 b4 02 b0 01 bb 00 7c b2 80 8a 74 03 02 |.........|...t..|
00000040 80 00 00 80 fc 49 08 00 00 08 fa 90 90 f6 c2 80 |.....I..........|
00000050 75 02 b2 80 ea 59 7c 00 00 31 c0 8e d8 8e d0 bc |u....Y|..1......|
00000060 00 20 fb a0 40 7c 3c ff 74 02 88 c2 52 f6 c2 80 |. ..@|<.t...R...|
00000070 74 54 b4 41 bb aa 55 cd 13 5a 52 72 49 81 fb 55 |tT.A..U..ZRrI..U|
00000080 aa 75 43 a0 41 7c 84 c0 75 05 83 e1 01 74 37 66 |.uC.A|..u....t7f|
00000090 8b 4c 10 be 05 7c c6 44 ff 01 66 8b 1e 44 7c c7 |.L...|.D..f..D|.|
000000a0 04 10 00 c7 44 02 01 00 66 89 5c 08 c7 44 06 00 |....D...f.\..D..|
000000b0 70 66 31 c0 89 44 04 66 89 44 0c b4 42 cd 13 72 |pf1..D.f.D..B..r|
000000c0 05 bb 00 70 eb 7d b4 08 cd 13 73 0a f6 c2 80 0f |...p.}....s.....|
000000d0 84 f0 00 e9 8d 00 be 05 7c c6 44 ff 00 66 31 c0 |........|.D..f1.|
000000e0 88 f0 40 66 89 44 04 31 d2 88 ca c1 e2 02 88 e8 |[email protected]........|
000000f0 88 f4 40 89 44 08 31 c0 88 d0 c0 e8 02 66 89 04 |[email protected]..|
00000100 66 a1 44 7c 66 31 d2 66 f7 34 88 54 0a 66 31 d2 |f.D|f1.f.4.T.f1.|
00000110 66 f7 74 04 88 54 0b 89 44 0c 3b 44 08 7d 3c 8a |f.t..T..D.;D.}<.|
00000120 54 0d c0 e2 06 8a 4c 0a fe c1 08 d1 8a 6c 0c 5a |T.....L......l.Z|
00000130 8a 74 0b bb 00 70 8e c3 31 db b8 01 02 cd 13 72 |.t...p..1......r|
00000140 2a 8c c3 8e 06 48 7c 60 1e b9 00 01 8e db 31 f6 |*....H|.......1.|
00000150 31 ff fc f3 a5 1f 61 ff 26 42 7c be 7f 7d e8 40 |1.....a.&B|..}.@|
00000160 00 eb 0e be 84 7d e8 38 00 eb 06 be 8e 7d e8 30 |.....}.8.....}.0|
00000170 00 be 93 7d e8 2a 00 eb fe 47 52 55 42 20 00 47 |...}.*...GRUB .G|
00000180 65 6f 6d 00 48 61 72 64 20 44 69 73 6b 00 52 65 |eom.Hard Disk.Re|
00000190 61 64 00 20 45 72 72 6f 72 00 bb 01 00 b4 0e cd |ad. Error.......|
000001a0 10 ac 3c 00 75 f4 c3 00 00 00 00 00 00 00 00 00 |..<.u...........|
000001b0 00 00 00 00 00 00 00 00 19 aa 09 00 00 00 80 20 |............... |
000001c0 21 00 83 dd 1e 3f 00 08 00 00 00 a0 0f 00 00 dd |!....?..........|
000001d0 1f 3f 8e fe ff ff 00 a8 0f 00 00 58 f0 04 00 00 |.?.........X....|
000001e0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
000001f0 00 00 00 00 00 00 00 00 00 00 00 00 00 00 55 aa |..............U.|
00000200 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
1+0 records in
1+0 records out
1048576 bytes (1.0 MB) copied, 0.0184614 s, 56.8 MB/s
マジックワード0044-0047h = 0x000849fc
00000040 80 00 00 80 **fc 49 08 00** 00 08 fa 90 90 f6 c2 80 |.....I..........|
[root@chief zul.kifal]# dd if=/dev/sda skip=$((0x849fc)) bs=512 count=1 | hexdump -C
1+0 records in
1+0 records out
512 bytes (512 B) copied, 0.00260914 s, 196 kB/s
00000000 52 56 5e bf f8 81 66 8b 2d 83 7d 04 00 0f 84 c4 |RV^...f.-.}.....|
00000010 00 80 7c ff 00 74 3e 66 8b 1d 66 31 c0 b0 7f 39 |..|..t>f..f1...9|
00000020 45 04 7f 03 8b 45 04 29 45 04 66 01 05 c7 04 10 |E....E.)E.f.....|
00000030 00 89 44 02 66 89 5c 08 c7 44 06 00 70 50 66 31 |..D.f.\..D..pPf1|
00000040 c0 89 44 04 66 89 44 0c b4 42 cd 13 0f 82 93 00 |..D.f.D..B......|
00000050 bb 00 70 eb 56 66 8b 05 66 31 d2 66 f7 34 88 54 |..p.Vf..f1.f.4.T|
00000060 0a 66 31 d2 66 f7 74 04 88 54 0b 89 44 0c 3b 44 |.f1.f.t..T..D.;D|
00000070 08 7d 68 8b 04 2a 44 0a 39 45 04 7f 03 8b 45 04 |.}h..*D.9E....E.|
00000080 29 45 04 66 01 05 8a 54 0d c0 e2 06 8a 4c 0a fe |)E.f...T.....L..|
00000090 c1 08 d1 8a 6c 0c 5a 52 8a 74 0b 50 bb 00 70 8e |....l.ZR.t.P..p.|
000000a0 c3 31 db b4 02 cd 13 72 3a 8c c3 8e 45 06 58 c1 |.1.....r:...E.X.|
000000b0 e0 05 01 45 06 60 1e c1 e0 04 89 c1 31 ff 31 f6 |...E........1.1.|
000000c0 8e db fc f3 a4 1f 61 83 7d 04 00 0f 85 42 ff 83 |......a.}....B..|
000000d0 ef 08 e9 34 ff 5a ea 00 82 00 00 be 05 81 e8 3d |...4.Z.........=|
000000e0 00 eb 06 be 0a 81 e8 35 00 be 0f 81 e8 2f 00 eb |.......5...../..|
000000f0 fe 4c 6f 61 64 69 6e 67 20 73 74 61 67 65 32 00 |.Loading stage2.|
00000100 2e 00 0d 0a 00 47 65 6f 6d 00 52 65 61 64 00 20 |.....Geom.Read. |
00000110 45 72 72 6f 72 00 bb 01 00 b4 0e cd 10 46 8a 04 |Error........F..|
00000120 3c 00 75 f2 c3 00 00 00 00 00 00 00 00 00 00 00 |<.u.............|
00000130 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|
*
000001f0 00 00 00 00 00 00 00 00 fd 49 08 00 f6 00 20 08 |.........I.... .|
00000200
(/boot)2048年から始まります。
# fdisk -lu /dev/sda
Disk /dev/sda: 42.9 GB, 42949672960 bytes
255 heads, 63 sectors/track, 5221 cylinders, total 83886080 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
Disk identifier: 0x0009aa19
Device Boot Start End Blocks Id System
/dev/sda1 * 2048 1026047 512000 83 Linux Par...
/dev/sda2 1026048 83886079 41430016 8e Linux LVM
誰でも説明していただきありがとうございます。
答え1
US/Red_Hat_Enterprise_Linux/3/html/Reference_Guide/s1-grub-whatis.html
GRUBは次のステップでメモリにロードされます。
最初のステップまたはデフォルトのブートローダは、BIOSによってMBR [1]からメモリに読み込まれます。デフォルトのブートローダはMBR内の512バイト未満のディスク領域にあり、ステップ1.5または2レベルのブートローダをロードできます。
フェーズ1ブートローダは、必要に応じてフェーズ1ブートローダをメモリに読み込みます。一部のハードウェアでは、2段階のブートローダに入るには中間段階が必要です。これは、/boot/パーティションがハードドライブの1024シリンダの上にある場合、またはLBAモードを使用している場合に発生することがあります。ステップ1.5ブートローダーは/ boot /パーティションまたはMBRおよび/ boot /パーティションの小さな部分にあります。
ステップ2またはセカンダリブートローダがメモリに読み込まれます。セカンダリブートローダは、GRUBメニューとコマンド環境を表示します。このインターフェイスを使用すると、起動するカーネルまたはオペレーティングシステムを選択したり、パラメータをカーネルに渡したり、システムパラメータを表示したりできます。
かなり明らかに見える2番目のステップは、実際のグラブバイナリです。実際には、ドキュメントにはgrub 2が名前でロードされることが示されています。
私はこれを試みます:
dd if=/dev/zero of=/boot/stage2
追加資料:
/boot/grubをチェックしてください:
stage1 ブートローダのコピー:
stage1
stage1_5のファイル:
e2fs_stage1_5
fat_stage1_5
jfs_stage1_5
minix_stage1_5
reiserfs_stage1_5
xfs_stage1_5
stage2ファイル:
stage2
グラップミラーリンク:
答え2
IBM PCブートBIOSシーケンスに準拠したコンピューターの場合:
- ディスクのMBR(絶対セクタ0)は、BIOSによってメモリ0000:7C00にロードされます。
- コードが実行されます。
IBMからW7まで
IBM PC がブートするために使用するコードは、ここで確認できます。
IBM® Personal Computer™ DOS 2.00 の最初の MBR バージョン
このコードには複数のバージョンがあり、starmanページにも表示されます。
これらのさまざまなバージョンの開始点は、次のページです。
MS-DOS 3.30からMS-Windows™95(A)へ
最も一般的なMBRコードの1つは次のとおりです。
MBR:MS-Windows™95B、98、98SE、およびME
ほとんどのコードバージョンは、次のボリュームブートレコード(VBR)をロードするために使用されます。パーティションの VBR は、パーティションテーブルからパーティションを起動可能としてマークし、実行がそのパーティションに転送されます。
(VBRは絶対ディスクセクタ0またはW7マスターブートレコーダー)
以下でこのアセンブラコメントを検索してください。W7マスターブートレコーダーページ:
;次のコードはINT 13、関数42h(「拡張読み取り」)を使用して読み取られます
。 ;;ブータブルパーティションの最初のセクタ(VBR)をメモリ位置0x7c00に配置します。
Windows™7(およびVista)VBR(ボリュームブートレコード)
これを読むのは面白いです。W7VBRページ:
;次のコードは、INT 13、関数42h(「拡張ディスクの読み取り」)を使用して、ブートレコード領域1のセクターの残りの15個のセクターを;メモリーの位置7E00から配置します。
ブートコードがMBR(ディスクセクタ0)から始まり、VBR(ボリュームブートレコード)と多く(W7の場合15)の後続のセクタをロードすることを確認できます。
幼虫
しかし、ここではGRUBについて話しているのでGRUBページ:
次のコードを検索してください。
[7C44] -> Note: A very important location for anyone using GRUB!
This (4-byte) Quad-Word contains the location of GRUB's
stage2 file in sectors! It's called "stage2_sector" in
the stage1.S code. If GRUB is installed in the MBR by a
distro that always includes a number of sectors from
stage2 immediately following the GRUB MBR, you will see
the bytes 01 00 00 00 in this location; otherwise, it
will point to stage2 in the "/boot/grub" directory.
これはほぼ常に01 00 00 00
(または単に次のセクタ)です。
これは、BIOSが絶対セクタ0(MBR)をロードし、MBRにインストールされているGRUBコードが次のセクタを読み続けるということです。 (GRUB2)最近のリリースのサイズcore.img
(〜60セクタまたは〜30kB)。今日のドライブはMBRの後ろに1MBの空き容量を残すので、問題はありません。 EFIディスクには、これらのコードごとに別々のパーティションがあり、問題(サイズの問題など)が少なくなります。
回答
以前のバージョンのGRUBは、MBRと次の62セクタのうちのいくつかまたはそれ以上にstage2(またはいくつかの特別な場合はオプションでステップ1.5)を記録します。
画像にも説明があります。ウィキペディアグラップページ。
GNUウェブサイトからGRUBイメージファイル10個:
stage1
This is an essential image used for booting up GRUB. Usually, this is
embedded in an MBR or the boot sector of a partition. Because a PC boot
sector is 512 bytes, the size of this image is exactly 512 bytes.
All stage1 must do is to load Stage 2 or Stage 1.5 from a local disk.
Because of the size restriction, stage1 encodes the location of Stage 2
(or Stage 1.5) in a block list format, so it never understand any
filesystem structure.
ノート:stage2は他の物理ディスクに書き込むことができます。GRUBページから:
[7C40] -> 80 ("Boot Drive") NOTE: For those of you with multi-OS
booting systems, if your Linux installation with GRUB's
See: remaining software (stage2, menu file, etc.) is located
7C5A somewhere other than on the Primary Master drive, this
value will be 81, 82, etc. depending upon which drive
that Linux OS's /boot/grub directory is located. In the
stage1.S file, it's called the GRUB_INVALID_DRIVE byte
and commented as: "the disk to load stage2 from." (The
word INVALID has something to do with the code logic.)
この回答が作成されたとき、LVM のディスク使用量に関する基本的な詳細は公開されませんでした。 LVMパーティションには多くのパーティションを含めることができ、通常はそうです。論理的(物理的ではない)パーティション。 LVMパーティションの構造は複雑で、この質問の範囲外です。与えられたパーティションテーブルに基づいて、これらのパーティションはパーティション1の後に来て、OPによって報告された(およそ)256MBで始まると言えば十分です。これがポインタが(物理)ディスク内で約256 MBを指す理由です(OPが報告したように)。
答え3
GRUB Legacyは、ステージ1.5の有無にかかわらず、さまざまな方法でインストールできます。
設置時レベル1.5、MBRのポインタはステップ1.5の始まりを指します。 MBRコードはステップ1.5の最初のブロックをロードします。このブロックのコードには、ロードする追加のブロックのリストと、手順2を見つける場所を指定するBIOSパーティション番号とファイル名が含まれています。
ただし、OPの場合はGRUB Legacyがすでにインストールされています。1.5ステップなしLoading stage2
、2番目の16進ダンプのテキストに示されているとおりです。この場合、MBRはステージ2の最初のブロックを直接ロードし、ステージ1.5の場合と同様に、最初のブロックにはロードする他のブロックのリストが含まれます。
ステージ 1.5 とステージ 2 の分離により、以前の DOS 互換ルール (トラック #1、ヘッド #0 の先頭から最初のパーティションの開始) を使用している場合でも、ステージ 1.5 が MBR と最初のパーティションの開始の間に含まれることがありますあります。ディスクでも同様です。 、最新のオペレーティングシステムのように、ブロック#2048(つまり、ディスクの先頭からちょうど1MiB)で起動するわけではありません。ステップ2はMBRとパーティションの始まりの間の領域に収まらないかもしれませんが、ステップ1.5は1つのファイルシステムタイプしか読み取れないため、サイズが小さくなります。
設置時レベル1.5、GRUB Legacyのステップ2は、絶対ブロック番号ではなくファイル名でロードされるため、通常のファイルのように処理できます。しかし、インストール後1.5ステップなし、ステップ2は、インストーラが配置したブロックの場所からディスクに移動できない可能性があります。ファイルが誤って移動されないように、ファイルシステムタイプ固有の操作を実行する必要があります。たとえば、VFATファイルシステムでは、フェーズ2ファイルは「システム」および「読み取り専用」属性で表示する必要があります。
もちろん、利用可能なスペースが正しい場合、インストーラはMBRと最初のパーティションの先頭の間にステップ2を含めることができます。この場合、ファイルシステム内の作業を中断することは問題になりません。
OPの2番目の16進ダンプの終わりは次のとおりです。
000001f0 00 00 00 00 00 00 00 00 fd 49 08 00 f6 00 20 08
これには、複数の8バイトブロックリスト構造にロードする追加ブロックの仕様が含まれています。この場合、「ブロック#0x000849fdで始まるブロック0x00f6を16ビットセグメントアドレス0x0820としてロードする」の1つだけがあります。ブロック番号は、完全なLBA48ブロック番号ではなく32ビットにすぎません。これは、GRUBレガシーが大容量ディスクの全容量にアクセスすることを制限します。
- BIOS(EFIを無効にする)はMBRを読み取り、パーティションテーブルを見つけ、GRUB stage1(最初の446バイト)をメモリにロードします。
これは絶対に正確です。
- 私の/bootパーティションは1024シリンダー未満であり、いくつかのドキュメントから私がインポートしたアイデアは、stage2が1024シリンダー未満の場合、GRUB stage1がstage2を直接ロードできることです。
技術的には、「32ビットLBAブロック番号でアドレス指定可能なすべての場所」ですが、そうでなければ正確です。 BIOSがLBAアクセスをサポートしていない場合は、「1024未満のシリンダー」が機能し、GRUBは以前のC / H / SスタイルのBIOS呼び出しに置き換える必要があります。しかし、2000以降のハードウェアではそうではありません。問題が発生してはいけません。
私が確認したいくつかのドキュメントでは、stage1.5がMBRの次のセクタ63の前にあると述べていますが、
もしstage1.5では、通常ここで終わります。そうではない〜しなければならないでもそこにいてください。上で述べたように、「セクタ63より前」は、最初のパーティションの開始に関する古いDOSルールに由来しています。
他の人は、ディスクの最初の1MB以内にどこにいても構わないと提案しました。
実際には、32ビットブロック番号でアドレス指定可能などこにでも可能ですが、最初の1MBがその場所にあります。通常つまり、手順1.5を完全に使用した場合です。 「最初の1MB」は、パーティションの開始をディスクの開始から正確に1MiBに設定する最新のSSD / SANフレンドリーな規則に由来します。これはかなり大きな電力であるため、より大きなブロックサイズによく合います。 、RAIDストライプサイズ、および/またはストレージハードウェアにある可能性があるその他のソート設定。
stage1.5はGRUB v2専用であり、以前のバージョンのGRUBには適用されないと主張する別の組織があります。
文書は正反対です。 stage1.5 は GRUB Legacy 専用です。ただ。
- GRUB stage2には、ファイルシステムを読み取り、カーネルとRAMディスクをロードし、コントロールをカーネルに渡すために必要なすべてのドライバ/モジュールがあります。
正しい。
- カーネルはRHEL / CENTOS 6でinitを起動し、RHEL / CENTOS 7でsystemdを起動します。
少し単純化されていますが、基本的に正しいです。
RHEL / CentOS 6では、最初のユーザースペースプロセスは最初に最初の/init
RAMディスクファイルで実行されます。これは実際に最後のジョブが実行されるか、または同様のスクリプトですexec switch_root <mountpoint_of_real_root_filesystem> /sbin/init <arguments>
。
/init
RHEL / CentOS 7は、実際にはプレフィックスを持ついくつかのシステム固有のパラメータを認識する特別なバージョンを実行するinitramfs内のリンクです。以前のバージョンのスクリプトと同様に、ルートファイルシステムにアクセスするために必要なすべてを設定し、実際のルートファイルシステムの「フル」バージョンを設定します。/usr/lib/systemd/systemd
systemd
rd.
/init
exec()
systemd
答え4
私がしたことは、Hiren.infoの自動グラブローダーを使用してUSBフラッシュドライブにロードするようにHirenのブートCDを設定してマウントすることでした。起動可能なHirenのUSBドライブがあれば、メインドライブのHDDを調整しました。パーティションのサイズは次のとおりです。バックエンドのフラッシュドライブで1GBを減らした後、未割り当て領域にext4パーティションを作成しました。次に私がしたことは、RIPLinuXのxtermでgrub2configコマンドを実行することで、インストールは比較的自動的に行われました。ウィザードを使用すると、grub2インストール用のパーティションとディレクトリを選択できます。ローダーをフラッシュドライブのプライマリパーティションでmbrに設定し、ext4 /boot/grubをgrub2ファイルのインストールディレクトリに設定しました。
何が起こったのかは、grub2 grldrがフラッシュドライブのプライマリパーティションルートの古いgrldrを置き換えたことです。新しいmenu.lstファイルを自動化ウィザードで選択した起動オプションに置き換える前に、古いmenu.lstファイルをバックアップできます。ステップ4または5のプロセスが完了したら(設定のデフォルトに従って)、単にシステムを再起動し、USBディスクを起動デバイスとして選択し、grub2 menu.lstが起動オプションをロードするときに文字「c」を入力するだけです。 。 grub2 コマンドインタフェースに入ります。これで、ポータブルgrub2環境を完全にロードして起動できます。
ここに投稿された追加スクリーンショット: https://www.minds.com/groups/profile/924192575922864128