对Linux的引导扇区的认识

简介:

根据对PC BIOS 的了解,引导时首先要读入引导扇区。

我安装完毕Oracle Enterprise Linux x86_64 5.3以后,用  fdisk -l 看,可以看到:

[root@localhost ~]# fdisk -l

Disk /dev/sda: 12.8 GB, 12884901888 bytes
255 heads, 63 sectors/track, 1566 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes

Device Boot Start End Blocks Id System
/dev/sda1 * 1 13 104391 83 Linux
/dev/sda2 14 1566 12474472+ 8e Linux LVM

可以看到分了两个区。

根据如下的说法,一个物理硬盘,最多可以分成四个区

(因为引导扇区512字节中。除了末尾两个字节为标志位,留下64个字节给分区表,一个分区表16个字节,一共可以容纳4个)

用如下命令读取其引导扇区的内容:

dd if=/dev/sda  of=/root/bootsector bs=512 count=1

把读出来的二进制文件拿出来看,内容如下:

复制代码
EB,48,90,10,8E,D0,BC,00,B0,B8,00,00,8E,D8,8E,C0,
FB,BE,00,7C,BF,00,06,B9,00,02,F3,A4,EA,21,06,00,
00,BE,BE,07,38,04,75,0B,83,C6,10,81,FE,FE,07,75,
F3,EB,16,B4,02,B0,01,BB,00,7C,B2,80,8A,74,03,02,
80,00,00,80,41,FC,02,00,00,08,FA,90,90,F6,C2,80,
75,02,B2,80,EA,59,7C,00,00,31,C0,8E,D8,8E,D0,BC,
00,20,FB,A0,40,7C,3C,FF,74,02,88,C2,52,BE,7F,7D,
E8,34,01,F6,C2,80,74,54,B4,41,BB,AA,55,CD,13,5A,
52,72,49,81,FB,55,AA,75,43,A0,41,7C,84,C0,75,05,
83,E1,01,74,37,66,8B,4C,10,BE,05,7C,C6,44,FF,01,
66,8B,1E,44,7C,C7,04,10,00,C7,44,02,01,00,66,89,
5C,08,C7,44,06,00,70,66,31,C0,89,44,04,66,89,44,
0C,B4,42,CD,13,72,05,BB,00,70,EB,7D,B4,08,CD,13,
73,0A,F6,C2,80,0F,84,EA,00,E9,8D,00,BE,05,7C,C6,
44,FF,00,66,31,C0,88,F0,40,66,89,44,04,31,D2,88,
CA,C1,E2,02,88,E8,88,F4,40,89,44,08,31,C0,88,D0,
C0,E8,02,66,89,04,66,A1,44,7C,66,31,D2,66,F7,34,
88,54,0A,66,31,D2,66,F7,74,04,88,54,0B,89,44,0C,
3B,44,08,7D,3C,8A,54,0D,C0,E2,06,8A,4C,0A,FE,C1,
08,D1,8A,6C,0C,5A,8A,74,0B,BB,00,70,8E,C3,31,DB,
B8,01,02,CD,13,72,2A,8C,C3,8E,06,48,7C,60,1E,B9,
00,01,8E,DB,31,F6,31,FF,FC,F3,A5,1F,61,FF,26,42,
7C,BE,85,7D,E8,40,00,EB,0E,BE,8A,7D,E8,38,00,EB,
06,BE,94,7D,E8,30,00,BE,99,7D,E8,2A,00,EB,FE,47,
52,55,42,20,00,47,65,6F,6D,00,48,61,72,64,20,44,
69,73,6B,00,52,65,61,64,00,20,45,72,72,6F,72,00,
BB,01,00,B4,0E,CD,10,AC,3C,00,75,F4,C3,00,00,00,
00,00,00,00,00,00,00,00,43,D2,06,00,00,00,80,01,
01,00,83,FE,3F,0C,3F,00,00,00,8E,2F,03,00,00,00,
01,0D,8E,FE,FF,FF,CD,2F,03,00,D1,B0,7C,01,00,00,
00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,
00,00,00,00,00,00,00,00,00,00,00,00,00,00,55,AA,
复制代码
                        80,01,
01,00,83,FE,3F,0C,3F,00,00,00,8E,2F,03,00,
是第一个分区表,第一个字节80表示是活动分区。就是这里的 /dev/sda1

                        00,00,
01,0D,8E,FE,FF,FF,CD,2F,03,00,D1,B0,7C,01,
是第二个分区,第一个字节 00表示是 非活动分区。就是这里的 /dev/sda2
参考:
http://www.docin.com/p-394748574.html

而 第 5 个字节,表达的是 分区类型:83 为Linux 分区,8e 为 Linux LVM 分区

如果我们把两个分区表的 第一个字节的80 和 00 互换改为:,
                         00,01,
01,00,83,FE,3F,0C,3F,00,00,00,8E,2F,03,00,80,00,

01,0D,8E,FE,FF,FF,CD,2F,03,00,D1,B0,7C,01,

然后把修改后的 bootsector 文件写回到引导扇区,
dd if=/bootector of=/dev/sda bs=512 count=1

再看fdisk -l ,会看到:

/dev/sda1 1 13 104391 83 Linux
/dev/sda2 * 14 1566 12474472+ 8e Linux LVM

可以看到 × 的位置发生了变化,* 就表示那个分区是活动的(就是有效的可引导分区)。

为了安全起见,应当再把 bootsector 的内容中 第一个字节的80 和 00 互换回来。
80,01,
01,00,83,FE,3F,0C,3F,00,00,00,8E,2F,03,00,00,00,

01,0D,8E,FE,FF,FF,CD,2F,03,00,D1,B0,7C,01,

dd if=/bootector of=/dev/sda bs=512 count=1








本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/10/19/2730878.html,如需转载请自行联系原作者

目录
相关文章
|
8月前
|
Shell Linux C语言
【Shell 命令集合 磁盘维护 】Linux 用于检测和标记坏扇区(bad blocks)mbadblocks命令使用教程
【Shell 命令集合 磁盘维护 】Linux 用于检测和标记坏扇区(bad blocks)mbadblocks命令使用教程
122 0
|
4月前
|
网络协议 Ubuntu Linux
用Qemu模拟vexpress-a9 (三)--- 实现用u-boot引导Linux内核
用Qemu模拟vexpress-a9 (三)--- 实现用u-boot引导Linux内核
|
5月前
|
Linux Windows
【Linux】grub命令行引导进入windows系统
【8月更文挑战第20天】在Linux中通过GRUB命令行引导Windows的方法包括:1) 进入GRUB命令行模式,启动时按`c`键;2) 使用`ls`查找含Windows引导文件的分区,如`bootmgr`或`ntldr`;3) 设置根设备`root=(hd0,msdos3)`与链加载器`chainloader +1`;4) 输入`boot`命令启动Windows。请注意实际步骤可能因系统配置而异。
646 2
|
安全 Linux
Linux常见维护报错,修复MBR引导/修复grub2菜单/内核文件丢失
Linux常见维护报错,修复MBR引导/修复grub2菜单/内核文件丢失
158 0
Linux常见维护报错,修复MBR引导/修复grub2菜单/内核文件丢失
|
8月前
|
Linux
Linux MBR扇区故障 引导修复
Linux MBR扇区故障 引导修复
|
8月前
|
监控 网络协议 算法
【Linux】引导流程
【Linux】引导流程
59 0
|
8月前
|
负载均衡 算法 Ubuntu
双核Linux内核的引导
双核Linux内核的引导
69 0
|
存储 安全 Linux
【看表情包学Linux】磁盘基础知识 | CHS 寻址 | 逻辑扇区 LBA | 索引节点 inode | 伪删除 inode bitmap 1→0
【看表情包学Linux】磁盘基础知识 | CHS 寻址 | 逻辑扇区 LBA | 索引节点 inode | 伪删除 inode bitmap 1→0
209 0
|
安全 Linux Shell
Linux操作系统引导过程
Linux操作系统引导过程
Linux操作系统引导过程
|
缓存 网络协议 安全
Linux 系统安全及应用(账号安全和引导登录控制)(4)
1 账号安全基本措施 1.1 系统账号清理 1.1.1 将非登录用户的Shell设为/sbin/nologin 在我们使用Linux系统时,除了用户创建的账号之外,还会产生系统或程序安装过程中产生的许多其他账号,除了超级用户root外,其他账号都是用来维护系统运作的,一般不允许登录,常见的非登录用户有bin、adm、mail、lp、nobody、ftp等。 查看/etc/passwd 文件,可以看到多个程序用户。
197 0