第七周学习总结–系统启动流程

写在前面

作为一个理工科的你,我相信你一定给自己或者给别人装过windows操作系统,作为windows操作系统都图形化了,因此我们可能很难去了解中间都发生了什么。比如使用U盘安装的时候,网上一大堆某某某U盘制作系统工具,按照网上的教程,制作完成以后,就可以在要装系统的电脑上点击电源键狂按F12(不同的电脑可能不同)进入BIOS设置了,然后就等着使用了。作为学习另一个使用命令行的操作系统,我们有必要了解一下它的启动工作流程。

细说流程

Linux系统的启动流程主要分为以下几个主要步骤,POST –> BootSequence(BIOS) –> BootLoader(MBR)–> Kernel(ramdisk、ramfs)–> rootfs(readonly)–> /sbin/init。

  • POST

按下主机电源键,主机会首先加载BIOS信息,主要负责检测系统外围关键设备(如:CPU、内存、显卡、I/O、键盘鼠标等)是否正常。如果硬件设备因为各自原因自检没有通过,则不会进行下一步启动,如果硬件设备没有问题,则转交给下一步执行启动。

  • BootSequence

按次序查找BIOS中各引导设备,第一个有引导程序的设备即为本次启动要用到的设备。

  • BootLoader

BootLoader称为引导加载器,位于磁盘中的MBR中,每个磁盘都有一个MBR,MBR是磁盘上的第一个扇区又叫做主引导扇区,是主机开机后访问磁盘时首先要读取的扇区,MBR扇区共有512个字节,其中的446个字节即存放bootloader,64个字节存放分区表,剩余的2字节存放校验信息。

在Linux中,BootLoader的具体实现是由grub程序实现的。grub分为三个阶段,第一个阶段存放于MBR中,第二个阶段也称为stage1.5阶段,存放于MBR之后的扇区,主要为第三阶段提供文件系统驱动。第三阶段也称为stage2阶段,存放于一个基本的磁盘分区上,主要是提供一个菜单,允许用户选择要启动的系统或不同的内核版本,把用户选定的内核装载到RAM(内存)中特点空间中,解压、展开,而后把整个系统控制权移交给内核,即完成把内核加载到内存空间中。

grub也有自己的配置文件/boot/grub/grub.conf,启动菜单就是通过读取此文件进行信息显示,文件大体如下图所示:

701

其中各配置参数:

  1. default=#: 设定默认启动的菜单项顺序;菜单项(title)编号从0开始;
  2. timeout=#:指定菜单项等待选项选择的超时时长;
  3. splashimage=(hd#,#)/PATH/TO/XPM_PIC_FILE:指明菜单背景图片文件路径;
  4. hiddenmenu:隐藏菜单;
  5. title TITLE:定义菜单项“标题”, 可出现多次;
  6. root (hd#,#):grub查找stage2及kernel文件所在设备分区;为grub的“根”;
  7. kernel /PATH/TO/VMLINUZ_FILE [PARAMETERS]:启动的内核;
  8. initrd /PATH/TO/INITRAMFS_FILE: 内核匹配的ramfs文件;

此外还能对grub菜单及内核启动进行认证处理,在上面配置文件中加入password [–md5] STRING项即可,加在title之前表示需要对编辑菜单进行认证,加在title之后表示对内核进行认证,需要认证以后才能启动内核。

702

grub还有自己的命令行接口,启动系统时,敲击任意键进入grub命令行接口模式,在grub界面可以按照提示输入e、b、c进行相应的编辑,在对应的title输入c即可进入命令行模式,有如下常用选项:

  1. help:获取帮助信息;
  2. find :文件查找,通常用于定位文件,find(hd#,#);
  3. root (hd#,#):把哪一个磁盘分区设置为根;
  4. kernel:设定本次启动时用到的内核文件;
  5. initrd:设定为选定的内核提供额外文件的ramdisk;

所以也可以通过手动指定来启动内核,在grub界面通过上述介绍的参数,依次输入:

  1. root (hd#,#);
  2. kernel /vmlinuz-VERSION-RELEASE  ro  root=/dev/DEVICE;
  3. initrd /initramfs-VERSION-RELEASE.img;
  4. boot;

来通过读取新指定的各参数启动内核。

703

  • Kernel

在kernal阶段,主要是通过前面步骤加载到的内核完成自身的初始化:

  1. 探测可识别到的所有硬件设备;
  2. 加载硬件驱动程序(有可能会借助于ramdisk加载驱动);
  3. 以只读方式挂载根文件系统;
  4. 运行用户空间的第一个应用程序:/sbin/init
  • rootfs

根切换,因为在内核加载阶段,系统有可能会借助ramdisk提供的一个简化版的根文件系统来提供驱动,完成后续步骤后ramdisk会加载真正的根文件系统,并把控制权移交给真正的根文件系统。

  • /sbin/init

内核被加载后,第一个运行的程序便是/sbin/init,该文件会读取/etc/inittab文件,设定Linux的运行级别并依据此来进行后续的初始化工作。

写在最后

今天的分享就到这里了,里面涉及到了Linux启动的一些基本流程,还特别提到了grub的两种实现方式,通过配置文件新增内核信息方式和grub命令行接口方式进行配置,如果我们熟知了Linux系统启动每步骤都需要什么文件,完成什么内容以后,我觉得配置都是很轻松的事情。实在没辙的话,不妨试试强大的搜索引擎,这也是学习的很好方法。

 

 

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/91102

(0)
虫草君虫草君
上一篇 2018-01-13 15:48
下一篇 2018-01-14 14:08

相关推荐

  • ps/top/htop/dstat命令的使用说明

    ps命令参数说明       ps命令是一种静态显示进程(process)状态的外部命令,获取的是某一个时间点的状态信息,其常用选项参数如下:         -A:all process信息    …

    Linux干货 2016-12-16
  • HA专题: corosync+pacemaker实现nginx高可用

    HA专题: corosync+pacemaker实现nginx高可用 前言 实验介绍 实验拓扑 实验环境 实验步骤 准备工作 安装HA集群组件 安装nginx和配置nfs 使用crmsh配置集群资源 测试 总结 前言 这几天都会学习高可用集群, 也会将其中的一些实验写出来分享给大家, 这个专题估计会写5篇左右, p.s: 写博客很累的 实验介绍 这次的实验比…

    Linux干货 2016-04-11
  • N22-第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 ~]# who | cut -d' ' -f1| uniq -u  执行前的情况:  执行后的情况:    &nbsp…

    Linux干货 2016-09-06
  • 网络分层基础概念与TCP,IP协议解析

    网络分层基础概念:   与ISO的OSI网络分层模型不同。网络分层事实上的标准为TCP/IP 的网络分层模型。   下图是他们是他们之间的对应关系。   左边为OSI网络分层模型。右边为TCP/IP的网络分层模型。 网络分层,是将一个大而复杂的网络,拆分为多个层次,每个层次单独完成自己的任务,多个层次再结合起来,完成一个复杂的通…

    2017-05-04
  • N25期–第七周作业

    1、创建一个10G分区,并格式为ext4文件系统; fdisk /dev/sda n p 2 enter +10G w partx -a /dev/sda (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; mke2fs -t ext4 -…

    Linux干货 2017-02-20
  • 马哥教育网络20期—nginx

    Nginx 一. Nginx 特性 二. Nginx 基本架构 三. Nginx 基本功能 四. Nginx 安装 五. Nginx 配置文件 六. Nginx http服务功能测试 七. Nginx LNMP 一. Nginx 特性 模块化,目前只能将模块编译进Nginx,暂时不支持动态装卸载模块.(httpd优势) 可靠性,一个主进程(master)控制…

    Linux干货 2016-06-26