CentOS系统管理
一、操作系统启动概念
不论是Windows还是Linux操作系统,底层设备一般均为物理硬件,操作系统启动之前会对硬件进行检查,然后硬盘引导启动操作系统。
1.1 BIOS(基本输入输出系统)
基本输入输出系统(Basic Input Output System,BIOS)是一组固化到计算机主板上的只读存储镜像(Read Only Memory image,ROM)芯片上的程序,它保存着计算机最重要的基本输入输出的程序、系统设置信息、开机后自检程序和系统自启动程序。其主要的功能是为计算机提供最底层的、最直接的硬件设置和控制。
全新硬盘在使用前必须进行分区格式化,硬盘分区初始化的格式主要有两种,分别是MBR格式、GPT格式。
1.2 MBR(主引导记录扇区)
如果使用MBR格式,操作系统将创建主引导记录扇区(Main Boot Record,MBR),MBR位于整块硬盘的0磁道0柱面1扇区,主要功能是操作系统对磁盘进行读写时,判断分区的合法性以及分区引导引导信息的定位。
主引导扇区总共为512Byte,MBR只占其中446Byte,另外的64Byte为硬盘分区表(Disk Partition Table,DPT),最后2Byte“55”,“AA”是分区的结束标志。
在MBR硬盘中,硬盘分区信息直接存储于主引导记录中,同时主引导记录还存储着系统的引导程序(如上图所示)。
MBR(Main Boot Record)是计算机启动最先执行的硬盘上的程序,只有512字节,因而不能够载入计算机核心的程序——引导程序。
因为MBR分区标准决定了MBR只支持在2TB
以下的硬盘,对于多余空间只能浪费。为了能支持使用大于2TB
硬盘空间,微软和英特尔公司在可扩展固件接口(Extensible Firmware Interface,EFI)方案中开发了全局唯一的标识符(Globally unique identifier,GUID),进而全面支持大于2TB
硬盘空间在企业中使用。
1.3 GPT
全局唯一标识符(GUID),正在逐步取代MBR成为新标准,它和统一的可扩展固件接口(Unified Extensible Firmware Interface,UEFI)相辅相成。UEFI用于取代老旧的BIOS,而GPT则取代老旧的MBR。
之所以称为“GUID分区表”,是因为驱动器上的每个分区都有一个全局唯一的标识符。
在GPT硬盘中,分区表的位置信息存储在GPT头中。出于兼容性考虑,第一个扇区同样有一个与MBR类似的标记——受保护的主引导记录(Protected Main Boot Record,PMBR)。其作用是当使用不支持GPT的分区工具时,整个硬盘将显示为一个受保护的分区,以防止分区表以及硬盘数据遭到损坏,其中存储的内容和MBR一样,之后才是GTP头。
GTP支持2T
以上磁盘,如果使用Fdisk分区,最大只能建立2TB
大小的分区,创建大于2TB
的分区,需要使用Parted,同时必须使用64位操作系统。
Mac、Linux系统都支持GPT分区格式;windows 7/8 64bit、windows server 2008 64bit支持GTP。
1.4 GRUB(GNU项目的多操作系统启动程序)
GNU项目的多操作系统启动程序(GRand Unified BootLoader,GRUB),可以支持多操作系统的引导,它允许用户可以在计算机上同时拥有多个操作系统,并在计算机启动时选择用户自己希望的操作系统。
GRUB可用于选择操作系统分区上的不同内核,也可以像这些操作系统的内核传递启动参数。
Linux常见的引导程序包括:LILO、GRUB、GRUB2、CentOS 7 Linux,默认使用 GRUB2 引导程序,引导系统启动。
GRUB2是基于GRUB开发成更加安全强大的多系统引导程序,最新Linux发行版都是以其作为引导程序。GRUB2采用了模块化设计、使得GRUB2核心更加精炼,使用更加灵活。
二、Linux操作系统启动流程
2.1 加载BIOS
计算机电源加电自检,首先加载BIOS,BIOS中间包含硬件CPU、内存、硬盘等相关信息,包含设备启动顺序、硬盘信息、内存信息、时钟信息、即插即用(Plug-and-Play)特性。加载完BIOS信息,计算机将会根据顺序进行启动。
2.2 读取MBR
读取完BIOS信息,计算机将会查找BIOS所指定的硬盘MBR引导扇区,将其内容复制到0x7c00
地址所在的物理内存中。被复制的内容——Boot Loader,然后进行引导。
2.3 GRUB引导
GRUB启动引导器是计算机启动过程中运行的第一个软件程序,当计算机读取内存中的GRUB配置信息后,会根据其配置信息来启动硬盘上不同的操作系统。
2.4 加载Kernel
计算机读取内存映像,并进行解压缩操作,屏幕一般会出现“Uncompressing Linux”的提示,当解压缩内核完成后,屏幕会输出“OK,booting the kernel”。系统将解压后的内核放置在内存中,并调用“start_kernel()函数”来启动一系列的初始化函数,并初始化各种设备,完成Linux核心环境的建立。
2.5 设定Inittab运行等级
内核加载完毕,会启动Linux操作系统的第一个守护进程init,然后通过该进程读取/etc/inittab文件,/etc/inittab文件的作用是设定Linux运行等级,Linux常见运行级别:
符号 | 运行模式 |
---|---|
0 | 关机模式 |
1 | 单用户模式 |
2 | 无线网络支持的多用户模式 |
3 | 字符界面的多用户模式 |
4 | 保留,未使用模式 |
5 | 图像界面多用户模式 |
6 | 重新引导系统,重启模式 |
2.6 加载rc.sysinit
读取完运行级别,Linux系统执行执行的第一个用户层文件“/etc/rc.d/rc.sysinit”,该文件功能包括:设定 PATH 运行变量、设定网络配置、启动swap分区、设定/proc、系统函数、配置SeLinux等。
2.7 加载内核模块
读取“/etc/modules.conf” 文件以及 “/etc/modules.d”目录下的文件来加载系统内核模块。该模块文件,可以后期添加、修改或删除。
2.8 启动运行级别程序
根据之前读取的运行级别,操作系统会运行rc0.d
到rc6.d
中的相应的脚本程序,来完成相应的初始化工作和启动相应的服务。
2.9 读取rc.local文件
操作系统启动完相应的服务之后,会读取执行“/etc/rc.d/rc.local”文件,可以将需要开机启动的任务加入到该文的末尾,系统会逐条去执行并启动相应的命令。如下图所示:
2.10 执行/bin/login程序
执行“/bin/login”程序,启动到系统登陆界面,操作系统等待用户输入用户名和密码,即可登录到Shell终端
。至此,Linux操作系统完成流程启动完毕。