Linux系统启动基本流程

Linux开机流程

如下图

开机启动

  1. 00×01、BISO自检

    硬件检查,检查硬件完整性,之后从开机BIOS开机硬件列表选择BOOT设备

    2. 00×02、MBR引导

    从bootloader446字节(只会读取一个硬盘的MBR),读取引导程序,读取分区表4*16字节,从MBR后一部

分扇读取数据,进入GRUBstage1.5,在这部分扇区寻找 文件系统驱动识别/boot分区

   3. 00×03、GRUB

    进入GRUBstage2阶段,读取GRUB配置文件grub.conf,确定root文件系统对应的磁盘分区,读取/initrd

(ramfs).-version.img内核镜像文件位置,加载内核模块

    4. 00×4、加载kernal

    加载kernal,探测硬件设备,确定硬件设备类型,从initrd/ramfs中加载对应的驱动,以只读readonly的方式 

挂载rootfs,启动第一个用户空间进程/sbin/init(cet6为upstart名字依旧叫init)

    5. 00×5执行/sbin/init(用户空间第一个进程

    A、  读取/etc/inittab

    inittab中定义了系统启动级别:0关机1单用户2无NFS的多用户文本界面3多用户文本界面4未启用5图形界面

    6. 重启

 id:3:initdefault: 

  • 每一行定义一种action以及与之对应的process

id:runlevel:action:process
action:
wait: 切换至此级别运行一次
respawn:此process终止,就重新启动之
initdefault:设定默认运行级别; process省略
sysinit:设定系统初始化方式,此处一般为指定
/etc/rc.d/rc.sysinit
ca::ctrlaltdel:/sbin/shutdown -t3 -r now
id:3:initdefault:
si::sysinit:/etc/rc.d/rc.sysinit
l0:0:wait:/etc/rc.d/rc 0
l1:1:wait:/etc/rc.d/rc 1...
l6:6:wait:/etc/rc.d/rc 6 

    B、/etc/rc.d/sysinit 系统初始化脚本
    (1) 设置主机名
    (2) 设置欢迎信息
    (3) 激活udevselinux
    (4)
挂载/etc/fstab文件中定义的文件系统
    (5) 检测根文件系统,并以读写方式重新挂载根文件系统
    (6) 设置系统时钟
    (7) 激活swap设备
    (8) 根据/etc/sysctl.conf文件设置内核参数
    (9) 激活lvmsoftware raid设备
    (10) 加载额外设备的驱动程序

    (11) 清理操作

    C、根据启动级别启动/etc/rc.d/rc{0..6}.d/*服务脚本下指定的脚本

    rc N –> 意味着读取/etc/rc.d/rcN.d/
    K*: K##*
##运行次序;数字越小,越先运行;数字
    越小的服务,通常为依赖到别的服务
    S*: S##*##运行次序;数字越小,越先运行;数字
    越小的服务,通常为被依赖到的服务
   

 for srv in /etc/rc.d/rcN.d/K*; do
            $srv stop
    done
    for srv in /etc/rc.d/rcN.d/S*; do
        $srv start
    done 

    D、getty(mingetty) /bin/login shell

    当我们看到mingetty的登录界面时,我们就可以输入用户名和密码来登录系统了。

    Linux的账号验证程序是login,login会接收mingetty传来的用户名作为用户名参数。然后
login会对用户名进行分析:如果用户名不是root,且存在/etc/nologin文件,login将输出
nologin文件的内容,然后退出。这通常用来系统维护时防止非root用户登录。只有/etc/securetty中登记了的终端才允许root用户登录,如果不存在这个文件,则root可以
在任何终端上登录。

    /etc/usertty文件用于对用户作出附加访问限制,如果不存在这个文件,
则没有其他限制。
在分析完用户名后,login将搜索/etc/passwd以及/etc/shadow来验证密码以及设置账户
的其它信息,比如:主目录是什么、使用何种shell。如果没有指定主目录,将默认为根目
录;如果没有指定shell,将默认为/bin/bash。

     login程序成功后,会向对应的终端在输出最近一次登录的信息(在/var/log/lastlog中有
记录),并检查用户是否有新邮件(在/usr/spool/mail/的对应用户名目录下)。然后开始设置
各种环境变量:对于bash来说,系统首先寻找/etc/profile脚本文件,并执行它;然后如果用
户的主目录中存在.bash_profile文件,就执行它,在这些文件中又可能调用了其它配置文
件,所有的配置文件执行后后,各种环境变量也设好了,这时会出现大家熟悉的命令行提示
符,到此整个启动过程就结束了。


原创文章,作者:Az2h1丶,如若转载,请注明出处:http://www.178linux.com/79551

(0)
Az2h1丶Az2h1丶
上一篇 2017-07-09 16:34
下一篇 2017-07-09 17:15

相关推荐

  • Linux网络属性管理

      ifconfig命令 ifconfig [interface] # ifconfig -a # ifconfig IFACE [up|down] ifconfig interface [aftype] options | address … # ifconfig IFACE IP/mask [up] # ifconfig IFACE…

    Linux干货 2015-09-26
  • keepalived(主主) 结合lvs(dr工作 模式) 实现高可用性。

    keepalived(主主) 结合lvs(dr工作 模式) 实现高可用性。

    2018-03-11
  • MAN手册、Linux文件系统等介绍

    适合人群:Linux初学者 主要内容: Man手册使用介绍        FHS文件系统介绍        Linux文件类型介绍        随堂笔记 操作环境:CentOs 6.8 ☆ MAN 手册介绍 man手册…

    Linux干货 2016-10-18
  • Linux发行版的基础目录名称、命名法则及功能规定

    Linux发行版的基础目录名称、命名法则及功能规定 / 主层次的根,也是整个文件系统层次结构的根目录  /bin 存放系统的命令。  /boot 存放系统的启动文件,及其内核。  /dev 系统设备文件主目录。  /etc 系统主要配置文件主目录。  /home 普通用户家目录。  /lib 系统库…

    Linux干货 2016-10-31
  • iptables基础概念

    iptables基本概念梳理 前言 netfilter/Iptables (其中包括netfilter和Iptables两个组件)组 成了Linux平台下的包过滤防火墙,它与大多数的Linux自带软 件一样,这个防火墙是免费提供的,它可以代替昂贵的企业级 防火墙来解决实际问题与实际方案,完成封包过滤,封包重定 向和网络地址转换等功能。 一、工作原理 数据包从…

    Linux干货 2016-12-19
  • 基础网络配置

    配置文件: /etc/ude /proc/sys/net/ipv4/ip_forward /etc/sysconfig/network-scripts/ifcfg-IFACE 网络配置文件 /etc/sysconfig/network-scripts/route-IFACE 路由配置文件 配置文件里的设置: DEVICE:此配置文件应用到的设备 HWADDR…

    Linux干货 2017-05-08