NTLDR一般存放于C盘根目录下,是一个具有隐藏和只读属性的系统文件。它的主要职责是解析Boot.ini文件。如果你对它的理解还不是很清楚,那么下面我们就以Windows XP为例介绍NTLDR在系统引导过程中的作用。 Windows XP在引导过程中将经历预引导、引导和加载内核三个阶段,这与Windows 9X直接读取引导扇区的方式来启动系统是xx不一样的,NTLDR在这三个阶段的引导过程中将起到至关重要的作用。 1.预引导阶段 在预引导阶段里计算机所做的工作有:运行POST程序,POST将检测系统的总内存以及其他硬件设备的状况,将磁盘{dy}个物理扇区加载到内存,加载硬盘主引导记录并运行,主引导记录会查找活动分区的起始位置。接着活动分区的引导扇区被加载并执行,{zh1}从引导扇区加载并初始化NTLDR文件。 2.引导阶段 在引导阶段中,Windows XP将会依次经历初始引导加载器阶段、操作系统选择阶段、硬件检测阶段以及配置选择阶段这四个小的阶段。 (1)在初始引导加载器阶段中,NTLDR将把计算机的微处理器从实模式转换为32位平面内存模式,在实模式中,系统会为MS-DOS预留640KB大小的内存空间,其余的内存都被看做是扩展内存,在32位平面模式中系统将所有内存都视为可用内存,然后NTLDR执行适当的小型文件系统驱动程序,这时NTLDR可以识别每一个用NTFS或FAT格式的文件系统分区,至此初始引导加载器阶段结束。 (2)当初始引导加载器阶段结束后将会进入操作系统选择阶段,如果计算机上安装了多个操作系统,由于NTLDR加载了正确的Boot.ini文件,那么在启动的时候将会出现要求选择操作系统的菜单,NTLDR正是从文件中查找到系统文件的分区位置。如果选择了NT系统,那么NTLDR将会运行文件,否则NTLDR将加载BOOTSECT.DOS,然后将控制权交给BOOTSECT.DOS。如果Boot.ini文件中只有一个操作系统或者其中的timeout值为0,那么将不会出现选择操作系统的菜单画面,如果Boot.ini文件非法或不存在,那么NTLDR将会尝试从默认系统卷启动系统。 小提示:NTLDR启动后,如果在系统根目录下发现有Hiberfil.sys文件且该文件有效,那么NTLDR将读取Hiberfil.sys文件里的信息并让系统恢复到休眠以前的状态,这时并不处理Boot.ini文件。 (3)当操作系统选择阶段结束后将会进入硬件检测阶段,这时NTDETECT.COM文件将会收集计算机中硬件信息列表,然后将列表返回到NTLDR,这样NTLDR将把这些硬件信息加载到注册表“HKEY_LOCAL_MACHINE”中的Hardware中。 (4)硬件检测阶段结束后将会进入配置选择阶段,如果有多个硬件配置列表,那么将会出现配置文件选择菜单,如果只有一个则不会显示。 3.加载内核阶段 在加载内核阶段中,NTLDR将加载NTOKRNL.EXE内核程序,然后NTLDR将加载硬件抽象层(HAL.dll),接着系统将加载注册表中的“HKEY_MACHINESystem”键值,这时NTLDR将读取“HKEY_MACHINESystemselect”键值来决定哪一个ControlSet将被加载。所加载的ControlSet将包含设备的驱动程序以及需要加载的服务。再接着NTLDR加载注册表“HKEY_LOCAL_MACHINESystemservice”下的start键值为0的底层设备驱动。当ControlSet的镜像CurrentControlSet被加载时,NTLDR将把控制权传递给NTOSKRNL.EXE,至此引导过程将结束。 小提示:如果在启动的时候按F8键,那么我们将会在启动菜单中看到多种选择启动模式,这时NTLDR将根据用户的选择来使用启动参数加载NT内核,用户也可以在Boot.ini文件里设置启动参数。 “BOOT.INI”文件会在已经安装了Windows NT/2000/XP的操作系统的所在分区,一般默认为C:下面存在。但是它默认具有隐藏和系统属性,所以你要设置你的文件夹选项,以便把“BOOT.INI”文件显示出来。我们可以用任何一种文本编辑器来打开他它。一般情况下,它的内容如下: timeout=30 default=multi(0)disk(0)rdisk(0)partition(1)Windows [operating systems] multi(0)disk(0)rdisk(0)partition(1)Windows="Microsoft Windows XP Professional" /fastdetect 在Windows 2000或者是XP系统中,我们可以很容易的设置“BOOT.INI”文件。那就是在“我的电脑”上面点击右键,选择“属性”打开“系统属性”对话框,再点击“高级”选项卡,在“启动和故障修复”里面点击“设置”按钮,就可以打开“启动和故障修复”对话框了,在这里面我们就可以对它进行详细设置。 如果你拥有Windows XP操作系统,那么你可以用“系统配置实用程序”来更方便的编辑“BOOT.INI”文件。具体做法是:打开“开始”菜单,点击“运行”命令,再在弹出的文本框中输入“msconfig”点击“确定”后就会弹出“系统配置实用程序”,再点击“BOOT.INI”选项卡,就会出现如图所示的界面。在这里,我们可以很方便地设置文件。 言归正传,现在,来说明一下这个文件内容的含义。 1.系统加载部分() 这一部分很简单,只有两个设定。那就是“timeout=”和“default=”。 “timeout=”就是设定开机时系统引导菜单显示的时间,超过设定值则自动加载下面“default=”指定的操作系统。默认值是30,单位为秒。我们可以在这里面设定等待时间的长短。如果将其设为“0”那么就是不显示系统引导菜单。 “default=”则是设定默认引导的操作系统。而等号后面的操作系统必须是已经在“[operating systems]”中存在的。如果想默认为加载另外的操作系统,我们可以参看“[operating systems]”中的操作系统列表,然后把想要加载的操作系统按照格式写到“default=”后面就可以了。 2.操作系统部分([operating systems]) 在这里面,列出了机器上所安装的全部操作系统。比如机器上只有一个操作系统,那么就只有一条信息,那就是“multi(0)disk(0)rdisk(0)partition(1)Windows="Microsoft Windows XP Professional" /fastdetect” 在这里需要注意的是,在英文引号内的文字就是引导操作系统菜单时显示出来的让我们选择操作系统的提示文字,在这里面我们可以随意更改。而“multi(0)disk(0)rdisk(0)partition(1) Windows”这一句就需要些解释了。因为它涉及ARC(高级RISC计算机)命名,它是x86或RISC计算机中用于标识设备的动态方法。 ARC命名的{dy}部分用于标识硬件适配卡/磁盘控制器,它有两个选项:SCSI和Multi。 Multi表示一个非SCSI硬盘或一个由SCSI BIOS访问的SCSI硬盘,而SCSI则表示一个SCSI BIOS禁止的SCSI硬盘。(x)是硬件适配卡序号。Disk(x)表示SCSI总线号。如果硬件适配卡为Multi,其正确表示方法就为disk(0),rdisk(x)则表示硬盘的序号,如果硬件适配卡为SCSI则忽略此值; partition(x)表示硬盘的分区序号。了解这些,我们就可以解释前面那条信息的含义了,即“multi(0)disk(0)rdisk(0)partition(1) Windows”为,在0号非SCSI设备上的第0号磁盘上的{dy}个分区里面的“Windows”目录下可以找到能够启动的操作系统。 等号后的内容前面已经说过,那个就是引导菜单显示出来的供我们选择的提示文字。而后面的“/fastdetect”又是作什么用的呢?这是一个开关符,用来控制启动该操作系统时的具体选项,下面再来详细的介绍各种开关符的含义: /3GB:这是Win2000 SP3新引入的。这使得用户区和系统区分为3G比1G的比例。只有用户使用NT企业版,应用程序也支持3GB选项时,此选项才生效。 /BASEVIDEO:使用标准VGA方式启动。这种方式主要用于显示驱动程序失效时。 /BAUDRATE:指出用于调度的波特率,如果用户不设置,则使用默认的9600,而对于线缆Modem则使用19200。 /BOOTLOG:使Win2000将日志写入 %SystemRoot%NTBTLOG.TXT 。 /BURNMEMORY=:使NT在已知的内存上少使用指定的数量,如果/burnmemory=64,则有64M内存NT不使用。 /CRASHDEBUG:调度器在NT启动时启动,只有在内核错误时才有用,如果系统经常会无故出错,这个选项就很有用了。 /DEBUG:在启动NT时调入调度器,它可以在任何时间xx,在错误可以再次出现时使用它比较合适。 /DEBUGPORT= comx :指定用于调度的端口,其它X就指端口号。 /FASTDETECT:对于Win2000启动时,它使系统不检查串行口和并行口。 /HAL=:允许用户不使用默认的HAL。 /INTAFFINITY:设置多处理器HAL(HALMPS.DLL),使编号{zd0}的处理器接收中断请求。如果不设置此选项,Win2000会使所有处理器接收中断请求。 /KERNEL=:与上面的功能相同,不过是针对SMP中的内核而言的。 /MAXMEM:n:指定NT可以使用的{zd0}内存数,如果一个内存片损坏,这个开关就十分有用了。 /NODEBUG:不使用调试信息。 /NOGUIBOOT:指定此选项会使Win2000不加载VGA驱动程序,也就不会显示启动过程和失败时的兰屏信息。 /NOSERIALMICE=[COMx | COMx,y,z…]:在特定的COM中上禁止对串行鼠标的检测。如果用户有一个非鼠标设备接在COM口上,这个选项会十分有用。如果此开关未加参数,系统会禁止所有COM口。 /NUMPROC=n:只允许前N个系统处理器工作。 /ONECPU:在多处理器中只使用一个处理器。 /PCILOCK:不让NT为PCI设置分配IO/IRQ资源,而启用BIOS设置。 /SAFEBOOT:安全启动,这个大家一定十分熟悉,Win2000只启动HKLMSystemCurrentControlSet ControlSafeBoot中的驱动程序和服务,其后跟三个参数MINIMAL,NETWORK或DSREPAIR之一。MINIMAL和NETWORK在允许网络下启动系统。而DSREPAIR要求系统从备份设备中调入活动目录的设置。还有一个选项是"(ALTERNATESHELL)",它让系统调入由HKLMSystemCurrentControlSet SafeBootAlternateShell指定的SHELL程序,而不使用默认的Explorer。 /SOS:在调入驱动程序名时显示它的名字,在因驱动问题而无法启动时使用比较好。 /WIN95:在装有三个系统DOS、Win9x和Windows NT的系统上,让NTLDR直接调用Win9x。启动文件BOOTSECT.W40。 /WIN95DOS:在装有三个系统DOS、Win9x和Windows NT的系统上,让NTLDR直接调用DOS启动文件BOOTSECT.DOS /YEAR=:使用指定的年份,如果设置为/YEAR=2005,那现在的时间就是2005年,此选项仅对NT4+SP4和Win2000生效。 Vista SP1以后引导文件发生改变 此处转自Win Vista系统的帮助和支持 boot.ini 文件发生了什么变化? 在 Windows 的较早版本中,boot.ini 是系统文件,它包含有关计算机上安装的 Windows 操作系统的信息。当您打开计算机时,在启动的过程中显示该信息。它在多重引导配置中或者对于需要自定义 Windows 启动方式的高级用户或管理员最有用。 在此版本的 Windows 中,boot.ini 文件已经替换为启动配置数据 (BCD)。该文件比 boot.ini 功能多,它可应用于使用其他方式而非基本输入/输出系统 (BIOS) 的计算机平台来启动计算机。 如果您需要对 BCD 进行更改(如从显示的操作系统列表中删除条目),请使用命令行工具 Bcdedit,它是专门用于管理员和 IT 专业人员的高级工具。有关 Bcdedit 的技术信息,请转到 Microsoft IT 专业人员网站。 如果您的计算机是多重引导配置,您仍然可以通过使用“控制面板”中的“系统”来更改默认情况下打开哪个 Windows 操作系统以及显示操作系统列表的时间。 单击打开“系统”。 在左窗格中,单击“高级系统设置”。 如果系统提示您输入管理员密码或进行确认,请键入密码或提供确认。 单击“高级”选项卡,然后在“启动和故障恢复”下单击“设置”。 在“系统启动”下,选择默认的操作系统以及显示操作系统列表所需的时间,然后单击“确定”。 Uinx和Linux系统下引导文件由于开源的方式引导可以用不同的程序常见的有Grub和Lilo(反过来是Loli) 下面转Linux 引导过程内幕(排版式修改) 从主引导记录到{dy}个用户空间应用程序的指导 级别: 初级 M. Tim Jones , 顾问工程师, Emulex 2006 年 7 月 26 日 引导 Linux® 系统的过程包括很多阶段。不管您是引导一个标准的 x86 桌面系统,还是引导一台嵌入式的 PowerPC® 机器,很多流程都惊人地相似。本文将探索 Linux 的引导过程,从最初的引导到启动{dy}个用户空间应用程序。在本文介绍的过程中,您将学习到各种与引导有关的主题,例如引导加载程序、内核解压、初始 RAM 磁盘以及 Linux 引导的其他一些元素。 早期时,启动一台计算机意味着要给计算机喂一条包含引导程序的纸带,或者手工使用前端面板地址/数据/控制开关来加载引导程序。尽管目前的计算机已经装备了很多工具来简化引导过程,但是这一切并没有对整个过程进行必要的简化。 让我们先从高级的视角来查看 Linux 引导过程,这样就可以看到整个过程的全貌了。然后将回顾一下在各个步骤到底发生了什么。在整个过程中,参考一下内核源代码可以帮助我们更好地了解内核源代码树,并在以后对其进行深入分析。 概述 图 1 是我们在 20,000 英尺的高度看到的视图。 图 1. Linux 引导过程在 20,000 英尺处的视图 当系统首次引导时,或系统被重置时,处理器会执行一个位于已知位置处的代码。在个人计算机(PC)中,这个位置在基本输入/输出系统(BIOS)中,它保存在主板上的闪存中。嵌入式系统中的中央处理单元(CPU)会调用这个重置向量来启动一个位于闪存/ROM 中的已知地址处的程序。在这两种情况下,结果都是相同的。因为 PC 提供了很多灵活性,BIOS 必须确定要使用哪个设备来引导系统。稍后我们将详细介绍这个过程。 当找到一个引导设备之后,{dy}阶段的引导加载程序就被装入 RAM 并执行。这个引导加载程序在大小上小于 512 字节(一个扇区),其作用是加载第二阶段的引导加载程序。 当第二阶段的引导加载程序被装入 RAM 并执行时,通常会显示一个动画屏幕,并将 Linux 和一个可选的初始 RAM 磁盘(临时根文件系统)加载到内存中。在加载映像时,第二阶段的引导加载程序就会将控制权交给内核映像,然后内核就可以进行解压和初始化了。在这个阶段中,第二阶段的引导加载程序会检测系统硬件、枚举系统链接的硬件设备、挂载根设备,然后加载必要的内核模块。完成这些操作之后启动{dy}个用户空间程序(init),并执行高级系统初始化工作。 这就是 Linux 引导的整个过程。现在让我们深入挖掘一下这个过程,并深入研究一下 Linux 引导过程的一些详细信息。 系统启动 系统启动阶段依赖于引导 Linux 系统上的硬件。在嵌入式平台中,当系统加电或重置时,会使用一个启动环境。这方面的例子包括 U-Boot、RedBoot 和 Lucent 的 MicroMonitor。嵌入式平台通常都是与引导监视器搭配销售的。这些程序位于目标硬件上的闪存中的某一段特殊区域,它们提供了将 Linux 内核映像下载到闪存并继续执行的方法。除了可以存储并引导 Linux 映像之外,这些引导监视器还执行一定级别的系统测试和硬件初始化过程。在嵌入式平台中,这些引导监视器通常会涉及{dy}阶段和第二阶段的引导加载程序。 提取 MBR 的信息 要查看 MBR 的内容,请使用下面的命令: # dd if=/dev/hda of=mbr.bin bs=512 count=1 # od -xa mbr.bin 这个 dd 命令需要以 root 用户的身份运行,它从 /dev/hda({dy}个 IDE 盘) 上读取前 512 个字节的内容,并将其写入 mbr.bin 文件中。od 命令会以十六进制和 ASCII 码格式打印这个二进制文件的内容。 在 PC 中,引导 Linux 是从 BIOS 中的地址 0xFFFF0 处开始的。BIOS 的{dy}个步骤是加电自检(POST)。POST 的工作是对硬件进行检测。BIOS 的第二个步骤是进行本地设备的枚举和初始化。 给定 BIOS 功能的不同用法之后,BIOS 由两部分组成:POST 代码和运行时服务。当 POST 完成之后,它被从内存中清理了出来,但是 BIOS 运行时服务依然保留在内存中,目标操作系统可以使用这些服务。 要引导一个操作系统,BIOS 运行时会按照 CMOS 的设置定义的顺序来搜索处于活动状态并且可以引导的设备。引导设备可以是软盘、CD-ROM、硬盘上的某个分区、网络上的某个设备,甚至是 USB 闪存。 通常,Linux 都是从硬盘上引导的,其中主引导记录(MBR)中包含主引导加载程序。MBR 是一个 512 字节大小的扇区,位于磁盘上的{dy}个扇区中(0 道 0 柱面 1 扇区)。当 MBR 被加载到 RAM 中之后,BIOS 就会将控制权交给 MBR。 {dy}阶段引导加载程序 MBR 中的主引导加载程序是一个 512 字节大小的映像,其中包含程序代码和一个小分区表(参见图 2)。前 446 个字节是主引导加载程序,其中包含可执行代码和错误消息文本。接下来的 64 个字节是分区表,其中包含 4 个分区的记录(每个记录的大小是 16 个字节)。MBR 以两个特殊数字的字节(0xAA55)结束。这个数字会用来进行 MBR 的有效性检查。 图 2. MBR 剖析 主引导加载程序的工作是查找并加载次引导加载程序(第二阶段)。它是通过在分区表中查找一个活动分区来实现这种功能的。当找到一个活动分区时,它会扫描分区表中的其他分区,以确保它们都不是活动的。当这个过程验证完成之后,就将活动分区的引导记录从这个设备中读入 RAM 中并执行它。 第二阶段引导加载程序 次引导加载程序(第二阶段引导加载程序)可以更形象地称为内核加载程序。这个阶段的任务是加载 Linux 内核和可选的初始 RAM 磁盘。 GRUB 阶段引导加载程序 /boot/grub 目录中包含了 stage1、stage1.5 和 stage2 引导加载程序,以及很多其他加载程序(例如,CR-ROM 使用的是 iso9660_stage_1_5)。 在 x86 PC 环境中,{dy}阶段和第二阶段的引导加载程序一起称为 Linux Loader(LILO)或 GRand Unified Bootloader(GRUB)。由于 LILO 有一些缺点,而 GRUB 克服了这些缺点,因此下面让我们就来看一下 GRUB。(有关 GRUB、LILO 和相关主题的更多内容,请参阅本文后面的 参考资料 部分的内容。) 关于 GRUB,很好的一件事情是它包含了有关 Linux 文件系统的知识。GRUB 不像 LILO 一样使用裸扇区,而是可以从 ext2 或 ext3 文件系统中加载 Linux 内核。它是通过将两阶段的引导加载程序转换成三阶段的引导加载程序来实现这项功能的。阶段 1 (MBR)引导了一个阶段 1.5 的引导加载程序,它可以理解包含 Linux 内核映像的特殊文件系统。这方面的例子包括 reiserfs_stage1_5(要从 Reiser 日志文件系统上进行加载)或 e2fs_stage1_5(要从 ext2 或 ext3 文件系统上进行加载)。当阶段 1.5 的引导加载程序被加载并运行时,阶段 2 的引导加载程序就可以进行加载了。 当阶段 2 加载之后,GRUB 就可以在请求时显示可用内核列表(在 /etc/grub.conf 中进行定义,同时还有几个软符号链接 /etc/grub/menu.lst 和 /etc/grub.conf)。我们可以选择内核甚至修改附加内核参数。另外,我们也可以使用一个命令行的 shell 对引导过程进行高级手工控制。 将第二阶段的引导加载程序加载到内存中之后,就可以对文件系统进行查询了,并将默认的内核映像和 initrd 映像加载到内存中。当这些映像文件准备好之后,阶段 2 的引导加载程序就可以调用内核映像了。 内核 GRUB 中的手工引导 在 GRUB 命令行中,我们可以使用 initrd 映像引导一个特定的内核,方法如下: grub> kernel /bzImage-2.6.14.2 [Linux-bzImage, setup=0x1400, size=0x29672e] grub> initrd /initrd-2.6.14.2.img [Linux-initrd @ 0x5f13000, 0xcc199 bytes] grub> boot Uncompressing Linux... Ok, booting the kernel. 如果您不知道要引导的内核的名称,只需使用斜线(/)然后按下 Tab 键即可。GRUB 会显示内核和 initrd 映像列表。 当内核映像被加载到内存中,并且阶段 2 的引导加载程序释放控制权之后,内核阶段就开始了。内核映像并不是一个可执行的内核,而是一个压缩过的内核映像。通常它是一个 zImage(压缩映像,小于 512KB)或一个 bzImage(较大的压缩映像,大于 512KB),它是提前使用 zlib 进行压缩过的。在这个内核映像前面是一个例程,它实现少量硬件设置,并对内核映像中包含的内核进行解压,然后将其放入xx内存中,如果有初始 RAM 磁盘映像,就会将它移动到内存中,并标明以后使用。然后该例程会调用内核,并开始启动内核引导的过程。 当 bzImage(用于 i386 映像)被调用时,我们从 ./arch/i386/boot/head.S 的 start 汇编例程开始执行(主要流程图请参看图 3)。这个例程会执行一些基本的硬件设置,并调用 ./arch/i386/boot/compressed/head.S 中的 startup_32 例程。此例程会设置一个基本的环境(堆栈等),并xx Block Started by Symbol(BSS)。然后调用一个叫做 decompress_kernel 的 C 函数(在 ./arch/i386/boot/compressed/misc.c 中)来解压内核。当内核被解压到内存中之后,就可以调用它了。这是另外一个 startup_32 函数,但是这个函数在 ./arch/i386/kernel/head.S 中。 在这个新的 startup_32 函数(也称为xx程序或进程 0)中,会对页表进行初始化,并启用内存分页功能。然后会为任何可选的浮点单元(FPU)检测 CPU 的类型,并将其存储起来供以后使用。然后调用 start_kernel 函数(在 init/main.c 中),它会将您带入与体系结构无关的 Linux 内核部分。实际上,这就是 Linux 内核的 main 函数。 图 3. Linux 内核 i386 引导的主要函数流程 通过调用 start_kernel,会调用一系列初始化函数来设置中断,执行进一步的内存配置,并加载初始 RAM 磁盘。{zh1},要调用 kernel_thread(在 arch/i386/kernel/process.c 中)来启动 init 函数,这是{dy}个用户空间进程(user-space process)。{zh1},启动空任务,现在调度器就可以接管控制权了(在调用 cpu_idle 之后)。通过启用中断,抢占式的调度器就可以周期性地接管控制权,从而提供多任务处理能力。 在内核引导过程中,初始 RAM 磁盘(initrd)是由阶段 2 引导加载程序加载到内存中的,它会被复制到 RAM 中并挂载到系统上。这个 initrd 会作为 RAM 中的临时根文件系统使用,并允许内核在没有挂载任何物理磁盘的情况下完整地实现引导。由于与外围设备进行交互所需要的模块可能是 initrd 的一部分,因此内核可以非常小,但是仍然需要支持大量可能的硬件配置。在内核引导之后,就可以正式装备根文件系统了(通过 pivot_root):此时会将 initrd 根文件系统卸载掉,并挂载真正的根文件系统。 decompress_kernel 输出 函数 decompress_kernel 就是显示我们通常看到的解压消息的地方: Uncompressing Linux... Ok, booting the kernel. initrd 函数让我们可以创建一个小型的 Linux 内核,其中包括作为可加载模块编译的驱动程序。这些可加载的模块为内核提供了访问磁盘和磁盘上的文件系统的方法,并为其他硬件提供了驱动程序。由于根文件系统是磁盘上的一个文件系统,因此 initrd 函数会提供一种启动方法来获得对磁盘的访问,并挂载真正的根文件系统。在一个没有硬盘的嵌入式环境中,initrd 可以是最终的根文件系统,或者也可以通过网络文件系统(NFS)来挂载最终的根文件系统。 Init 当内核被引导并进行初始化之后,内核就可以启动自己的{dy}个用户空间应用程序了。这是{dy}个调用的使用标准 C 库编译的程序。在此之前,还没有执行任何标准的 C 应用程序。 在桌面 Linux 系统上,{dy}个启动的程序通常是 /sbin/init。但是这不是一定的。很少有嵌入式系统会需要使用 init 所提供的丰富初始化功能(这是通过 /etc/inittab 进行配置的)。在很多情况下,我们可以调用一个简单的 shell 脚本来启动必需的嵌入式应用程序。 结束语 与 Linux 本身非常类似,Linux 的引导过程也非常灵活,可以支持众多的处理器和硬件平台。最初,加载引导加载程序提供了一种简单的方法,不用任何花架子就可以引导 Linux。LILO 引导加载程序对引导能力进行了扩充,但是它却缺少文件系统的感知能力。{zx1}一代的引导加载程序,例如 GRUB,允许 Linux 从一些文件系统(从 Minix 到 Reise)上进行引导。 Linux引导grub和lilo的基本知识作者vivelo 目前,PC的性能越来越强大,尤其是超大容量的硬盘使我们有足够的地方去安装多个操作系统。Linux下最常用的多重启动软件就是LILO和Grub。 LILO是现在许多Linux缺省的引导程序,它的全称是Linux Loader,拥有很强大的功能。Grub 也是一个多重启动管理器,它的全称是Grand Unified Bootloader。Grub的功能与LILO一样,也是在多个操作系统共存时选择引导哪个系统。它可以引导很多PC上常用的操作系统,其中就有Linux、FreeBSD、Solaris、Windows 9x、Windows NT;可以载入操作系统的内核和初始化操作系统;可以把引导权直接交给操作系统来完成引导;可以直接从FAT、minix、FFS、ext2或ext3分区读取Linux内核。Grub 有一个特殊的交互式控制台方式,可以手工装入内核并选择引导分区。 初识Grub和LILO 1.Grub与LILO的优缺点 由于Grub出现要比LILO晚,所以它可以实现LILO的绝大部分功能,可以代替LILO来完成对Linux的引导,特别适用于Linux与其它操作系统共存情况。 ◆ 8.4GB问题 以前大多数Linux所带较旧版本的LILO都有这样的一个问题:启动/boot分区不能分在超过1023柱面的地方,一般是在8.4GB左右的地方,否则LILO不能安装,或者安装后不能正确引导系统。Grub就不会出现这种情况,只要安装时大硬盘是在LBA模式下,它就可以引导根分区在8GB以外的操作系统。目前,在LILO较新的版本中这个问题已经做了很好处理。 ◆ 漂亮的Logo Grub引导开机显示一个漂亮的开机画面,它可以是640×480、800×600、1024×768等各种模式画面, 而且可以支持自动选择{zj0}图像模式。Linux爱好者可以通过改变这幅图片来制作个性化开机画面。 LILO源于文字界面,因此它在{zx1}的版本中对开机画面的支持也是很有限的。 ◆ 执行模式 Grub不但可以通过配置文件进行引导,还可以在选择引导前动态改变引导参数,动态加载各种设备。例如,在Linux下编译了一个新的核心,但不能确定它能不能工作,就可以在引导时动态改变Grub的参数,此时即使Grub菜单配置不正确,但仍可以引导系统。Grub的命令行有非常强大的功能,而且支持如bash一样的历史功能,可以用上下键来寻找以前的命令。LILO就不支持这种模式。 在LILO下,既可以手工输入操作系统的名字来引导不同的操作系统,也可使用一个菜单来选择不同的系统进行引导。Grub也兼容以上的操作。 ◆ 分区对Grub与LILO的影响 LILO是通过读取硬盘上的{jd1}扇区来装入操作系统,因此每次分区改变都必须重新配置LILO,如果调整了分区的大小及分区的分配,那么LILO在重新配置之前就不能引导这个分区的操作系统了。而Grub是通过文件系统直接把核心读取到内存,因此只要操作系统核心的路径没有改变,Grub就可以引导系统。 Grub和LILO支持多种外部设备,支持多种文件系统,动态装载操作系统内核,甚至可以通过网络装载操作系统核心。Grub还支持多种可执行文件格式,支持自动解压,可以引导不支持多重引导的操作系统等。 Grub和LILO的参数比较 1.安装 敲入“makebootable”命令,就可以安装Grub。而“lilo -v”则是重新安装LILO。LILO引导扇区包括一个分区表的空间,所以LILO既可以安装在MBR中,也可以安装在某个分区的引导扇区。Grub和LILO同时都可以安装在软盘之中。制作Grub的启动盘和制作LILO的启动盘相差不大。 要制作引导盘,需执行一些简单的步骤。首先确定Grub或LILO已经安装,并且在新的软盘上创建 ext2文件系统。然后进行安装,将一张空盘插入软驱,输入: #mke2fs /dev/fd0 创建了ext2文件系统后,需要安装该文件系统。 (1)安装Grub 进入Grub的目录: #cd /boot/grub 放入一张软盘,执行以下命令: #dd if=stage1 of=/dev/fd0 bs=512 count=1 #dd if=stage2 of=/dev/fd0 bs512 seek=1 Grub启动盘就完成了。 (2)安装LILO #dd if=/dev/hda of=/dev/fd0 bs=512 count=1(因为LILO已经安装在MBR中) 执行上述命令后LILO启动盘就完成了。 Grub启动时,会在/boot/grub/中寻找一个名字为menu.lst的配置文件,如果找不到此文件则不进入菜单模式直接进入命令行模式。menu.lst 是一个文本文件,可以用任何一个文本编辑器打开它。每一行代表一个配置命令,如果一行的{dy}个字符为“#”,则表明这一行为注释,可以简单地用增加或减少注释行来改变配置。LILO使用一个文本文件/etc/lilo.conf作为其配置文件。LILO读取lilo.conf,按照其中的参数将特定的LILO写入系统引导区。如果修改了/etc/lilo.conf,就必须重新运行LILO命令,以保证LILO正常运行。 Grub和LILO有很多的相似的参数,见表1所示。 表1 Grub和LILO参数比较 相似功能 Grub的具体参数 LILO的具体参数 在second秒之后引导默认的操作系统 timeout second timeout=tsecs 默认启动选项 default num default=name 指定操作系统的名字和描述 title OS mode label 指出linux内核的路径 Kernel image 指出开机画面的文件所存放的路径和文件名 Splash pathname/filename message=message-file 2.配置 (1)Grub和LILO共同的配置(括号内为LILO的参数) 指定引导默认的操作系统的等待时间: timeout second(timeout=tsecs) 上面代码表明设定second秒之后引导默认的操作系统。如果是timeout 5,就是5秒没有其它指令就引导系统;如果设成-1,则Grub会一直等待直到用户选择一个选项为止。 LILO中,timeout=50同样设置等待键盘输入的时长,单位是0.1秒。超过这段时间没有输入则为超时,系统将自动引导缺省的操作系统。如果不设置本参数,缺省的超时时间长度为无穷大。 指定引导的默认操作系统: default num(default=name) Grub中默认启动第num+1行的操作系统,default=1则启动第2个系统。LILO中是通过default=name指定缺省引导的操作系统,如default=LINUX表示将label为Linux的系统作为缺省引导的操作系统。如不指定该参数,排在lilo.conf中的{dy}个操作系统将作为缺省操作系统。 指定引导的操作系统的内核: Kernel(image) 给Grub指定内核在哪儿,还要指出哪个文件是内核文件。例如kernel /boot/vmlinuz-2.2.16 root=/dev/hda7 ro说明/boot/vmlinuz-2.2.16 就是要载入的内核,后面的都是传递给内核的参数。root=/dev/hda7就是Linux根分区的所在分区,ro以只读的方式打开。 LILO中是以image=filename来指定含有一个Linux内核的启动选项的文件或设备。 指定引导操作系统时的信息文件: Splash pathname/filename(message=message-file) 上面代码指出Grub开机画面文件所存放的路径和文件名。LILO中,message=message-file命令用于指定一个包含注释信息的文件,该文件将在系统“LILO”之前显示。如果在LILO启动时想获取较多的信息,可以编辑这个文件,再使用该命令就可以了。文件中如果包含有ASCⅡ码为0xFF的字符(Ctrl+L)则表示清屏。注意,文件的大小不能超过65535个字节。每次文件改变之后,都必须重新运行LILO命令重建map文件,以保证其正常显示。 指定引导操作系统的名称: title OS mode(label) 上面代码指出的字符就是Grub菜单项上所看见的选项,你可以写上操作系统的名字和描述,如用 title Linux、 Single Mode代表这一选项是引导此Linux的单用户模式。在LILO中,label=name通过此参数来标识当前操作系统,即操作系统名。用户可通过在LILO提示后输入name来引导特定的操作系统。
|