CentOS系统启动流程

Linux系统(Centos 5、6)启动流程

123.jpg

一、POST加电自检

Power-On-Self-Test 
按下电源键以后,系统调用存储在ROM中的BIOS和存储在RAM中的CMOS(用来保存各项参数的设定)完成系统硬件状态的检查,如果硬件有问题则提示用户问题严重无法开机的会发出警报声音;硬件自检完成后进入下一步。

二、Boot Sequence与MBR

  1. 加电自检完成后,系统会读取BIOS中的Boot Sequence中设置的引导顺序按次序检查。第一个有引导程序的设备既为本次启动需要用到的设备。

  2. 寻找到启动需要的设备后,寻找存储与该设备MBR前446个字节中的bootloader引导加载器进入下一阶段。

    1479977244939269.jpg

三、GRUB阶段

  1. 1st 、 运行bootloader,由于只有446个字节这里是用来加载下一步进程而不是内核。

  2. 1.5st、加载识别文件系统,如果此步骤无法运行就无法正常识别/boot所在分区。

  3. 2nd、 读取/boot/grub/grub.conf配置文件加载内核。

[root@CentOS6 ~]# cat /boot/grub/grub.conf
# grub.conf generated by anaconda
#
# Note that you do not have to rerun grub after making changes to this file
# NOTICE:  You have a /boot partition.  This means that
#          all kernel and initrd paths are relative to /boot/, eg.
#          root (hd0,0)
#          kernel /vmlinuz-version ro root=/dev/sda2
#          initrd /initrd-[generic-]version.img
#boot=/dev/sda
default=0   #系统默认
timeout=5   #超时时间
splashimage=(hd0,0)/grub/splash.xpm.gz   #grub启动壁纸
hiddenmenu  
title CentOS 6 (2.6.32-642.el6.x86_64)  #grub标题
   root (hd0,0) #指定根所在的位置
   kernel /vmlinuz-2.6.32-642.el6.x86_64 ro root=UUID=55ce0d77-cab0-4da4-bb2b-0af5adebf8d6 rd_NO_LUKS rd_NO_LVMLANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 crashkernel=auto  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb quiet  #指定内核位置并只读挂载
   initrd /initramfs-2.6.32-642.el6.x86_64.img #指定init位置

四、Kernel阶段

  1. 探测可识别的所有硬件设备;

  2. 加载硬件驱动程序;(有可能会借助于randdisk加载驱动)

  3. 以只读方式挂载根文件系统;

  4. 运行用户空间的第一个应用程序:/sbin/init

五、init初始化

(1)设置默认运行级别(配置文件:/etc/inittab)

运行级别:为了系统的运行或维护等墓地而设定的机制;

[root@C6red ~]# cat /etc/inittab

# Default runlevel. The runlevels used are:
#   0 - halt (Do NOT set initdefault to this)
#   1 - Single user mode
#   2 - Multiuser, without NFS (The same as 3, if you do not have networking)
#   3 - Full multiuser mode
#   4 - unused
#   5 - X11
#   6 - reboot (Do NOT set initdefault to this)
id:3:initdefault:
这里默认级别是3 、 配置文件中的格式是:id:runlevel:action:process。

0-6级别定义
0:关机,shutdown
1:单用户模式(single user),root用户,无需认证;维护模式;
2;多用户模式(multi user),会启动网络功能,但不会启动NFS;维护模式
3;多用户模式(multi user),完全功能模式;文本界面;
4:预留级别;目前无特别使用目的;同3
5:多用户模式(multi user),完全功能模式,图形界面;
6:重启模式,reboot;

默认级别:3、5 
级别切换:init #

[root@C6red ~]# init 4
[root@C6red ~]# who -r
        run-level 4  2016-11-22 21:25                   last=3

级别查看: who -r runlevel

[root@C6red ~]# who -r
        run-level 3  2016-11-22 10:05
[root@C6red ~]# runlevel
N 3
[root@C6red ~]#

(2) 运行系统初始化脚本,完成系统初始化 (/etc/rc.d/rc.sysinit)

[root@CentOS6 ~]# cat /etc/rc.d/rc.sysinit
#!/bin/bash
#
# /etc/rc.d/rc.sysinit - run once at boot time
#
# Taken in part from Miquel van Smoorenburg's bcheckrc.
#

HOSTNAME=$(/bin/hostname)

set -m

if [ -f /etc/sysconfig/network ]; then
   . /etc/sysconfig/network
fi
if [ -z "$HOSTNAME" -o "$HOSTNAME" = "(none)" ]; then
   HOSTNAME=localhost
fi

if [ ! -e /proc/mounts ]; then
   mount -n -t proc /proc /proc
   mount -n -t sysfs /sys /sys >/dev/null 2>&1
fi
if [ ! -d /proc/bus/usb ]; then
   modprobe usbcore >/dev/null 2>&1 && mount -n -t usbfs /proc/bus/usb /proc/bus/usb
else
   mount -n -t usbfs /proc/bus/usb /proc/bus/usb
fi

#remount /dev/shm to set attributes from fstab #669700
mount -n -o remount /dev/shm >/dev/null 2>&1
#remount /proc to set attributes from fstab #984003
mount -n -o remount /proc >/dev/null 2>&1
#####脚本过长以下省略######
主要执行了以下操作


(1)  设置主机名
(2)  设置欢迎信息
(3)  激活udev 和selinux
(4)  挂载/etc/fstab 文件中定义的文件系统
(5)  检测根文件系统,并以读写方式重新挂载根文件系统
(6)  设置系统时钟
(7)  激活swap 设备
(8)  根据/etc/sysctl.conf 文件设置内核参数
(9)  激活lvm 及software raid 设备
(10)  加载额外设备的驱动程序
(11) 执行清理操作

(3) 关闭对应级别下需要停止的服务,启动对应级别下需要开启的服务; 
(4) 设置登陆终端[5级别启动图形界面]


至此Centos6系统启动完成

原创文章,作者:M21-13-王振中,如若转载,请注明出处:http://www.178linux.com/60614

(0)
M21-13-王振中M21-13-王振中
上一篇 2016-11-24
下一篇 2016-11-24

相关推荐

  • N26-博客作业-week7

    1、创建一个10G分区,并格式为ext4文件系统;      (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;     ~]# fdisk /dev/sda Welcome to fdisk (util-li…

    Linux干货 2017-03-19
  • bash的基本特性之globbing,IO重定向及管道

    bash的基本特性之globbing,IO重定向及管道 giobbing:文件名通配 在bash的操作环境中有一个分厂有用的功能那就是gilobbing:文件名通配,这样我们在处理数据的时候就更方便了。下面我们来罗列一些常用的通配符。(注:globbing是做整体的文件名匹配而非部分) 匹配模式:元字符 *:表示匹配任意长度的任意字符  &nbsp…

    Linux干货 2016-12-19
  • 2016/10/14作业

    2016/10/14作业: ##操作类: 1. 设置自己的终端提示符,要求字符终端登录时: a> 需要带颜色  b> 需要显示当前执行到了第几条命令  c> 显示当前登录终端,主机名和当前时间 答:要在用户登录时终端提示符,需要更改当前系统的环境变量: /etc/bashrc文件 #[ "$PS1" …

    Linux干货 2016-10-19
  • linux基础知识:文件管理,bash特性

    本文简要介绍了文件类的管理命令,包括mv、cp、mkdir等等。还介绍了一些万用字符的用法。

    2017-12-12
  • 以水浒为例解释文件权限

    关于文件权限的内容学起来比较绕,稍不注意就会把自己绕晕,这时候不如找一个例子来记忆,这样记起来比较容易而且还会记忆深刻,接下来就以水浒为例解释下关于文件权限方面的内容 桃园三结义,兄弟三人组成一个组,选刘备当大哥,兄弟三人都在这个组里 兄弟三人还是居无定所的,要给刘关张兄弟三人造个房子,给兄弟三人一个容身之所,而且给兄弟三人一人一个房间   但建好…

    2017-07-30
  • N26-第四周博客

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost skel]# cp -r /etc/skel /home/tuser1[root@localhost skel]# chmod -R go=— /home/tuser1 2、编辑/etc/…

    系统运维 2017-02-08