操作系统启动
文章知识点来源
一、boot
boot表示启动
- 最早的时候,工程师们用它来比喻,计算机启动是一个很矛盾的过程:必须先运行程序,然后计算机才能启动,但是计算机不启动就无法运行程序!
- 所以需要将一段程序装进内存,这个过程叫做boot;
二 、BIOS
bios放在只读内存ROM里面,是计算机最先运行的程序;
1、首先硬件自检,确定硬件没有问题。
2、根据BIOS设定的启动顺序(比如重装系统时候的U盘启动),将控制 权交给该设备。
三、主引导记录
- 根据用户指定的引导顺序从软盘、硬盘或是可移动设备中读取启动设备的MBR,并放入指定的位置(0x7c000)内存中。
- MBR放在该设备的第一个扇区(512字节)
如果这512个字节的最后两个字节是0x55和0xAA,表明这个设备可以用于启动;如果不是,表明设备不能用于启动,控制权于是被转交给”启动顺序”中的下一个设备。
主引导记录结构:
1、1-446字节:bootloader(安装管理器)
2、447-510字节:分区表,分成四部分,每部分16字节,表示一个主分区或者逻辑分区,总共64字节;
3、511-512字节:主引导记录签名(0x55和0xAA)
四个分区里面只有一个是安装有操作系统,可以激活的;
每个分区包括能否激活,起止扇区,扇区数量,分区类型;
四、硬盘启动
- 计算机会读取激活分区的第一个扇区,叫做”卷引导记录”(Volume boot record,缩写为VBR),“卷引导记录”的主要作用是,告诉计算机,操作系统在这个分区里的位置。然后,计算机就会加载操作系统了。
- 如果操作系统在逻辑分区里面,在这种情况下,计算机读取”主引导记录”前面446字节的机器码之后,不再把控制权转交给某一个分区,而是运行事先安装的”启动管理器”(boot loader),由用户选择启动哪一个操作系统。
五、操作系统
- 控制权转交给操作系统后,操作系统的内核首先被载入内存。
- 以Linux系统为例,先载入/boot目录下面的kernel。内核加载成功后,第一个运行的程序是/sbin/init。它根据配置文件(Debian系统是/etc/initab)产生init进程。这是Linux启动后的第一个进程,pid进程编号为1,其他进程都是它的后代。
- 然后,init线程加载系统的各个模块,比如窗口程序和网络程序,直至执行/bin/login程序,跳出登录界面,等待用户输入用户名和密码。
- 至此,全部启动过程完成。