linux开机流程
- 开机BIOS自检,Base-Input-output-system找到启动设备
- 读取启动设备上的引导程序lilo或grub,如:硬盘指定位置,MBR分区(master-boot-record)主引导记录
- grub引导Linux菜单(boot loader),忘记密码可在这步进入类win的安全模式
- linux操作系统接管硬件,先读入/boot下内核文件,加载kernel内核
- 启动第一个程序(所以pid=1,其他所有进程都是其子进程),/sbin/init进程,初始化系统环境,根据/etc/inittab文件设定的运行级别
- init进程,执行rc.sysinit(bash的一个脚本,是每个运行级别首先运行的脚本) 调用rcX/下的链接,找到init.d中的sh脚本,开启开机自启服务,即守护进程deamon(半人半神精灵),在win中对应服务,rc.local在rcX脚本之后运行(有些没有rc.local)
rc.sysinit作用:激活交换分区,检查磁盘,加载硬件模块以及其它一些需要优先执行任务
init.d/下的脚本一般能接受start、stop、restart、status
7个(runlevel):
0:系统停机状态,系统默认运行级别不能设为0,否则不能正常启动
1:单用户工作状态,root权限,用于系统维护,禁止远程登陆
2:多用户状态(没有NFS)
3:完全的多用户状态(有NFS),登陆后进入控制台命令行模式
4:系统未使用,保留
5:X11控制台,登陆后进入图形GUI模式
6:系统正常关闭并重启,默认运行级别不能设为6,否则不能正常启动- 在每个运行级别中运行哪些守护进程,可通过chkconfig或者setup中的system services自行设定
- 建立终端,rc执行完后,基本系统环境也设置结束,init会开启6个终端(inittab中的6行定义6个终端ttyx),登录,login shell
- 命令行登录方式:init进程调用getty程序(get teletype),用户输入用户名和密码后调用login程序,核对(debian会再多运行一个身份核对程序/etc/pam.d/login)密码正确则从/etc/passwd中读取该用户指定shell,启动。 默认的shell,bash会读入/etc/profile配置(该路径对所有用户有效)寻找以下三个用户配置文件,~/.bash_profile ~/.bash_login ~/.profile 找到一个即可
- ssh登录方式:init进程调用sshd,(debian加运行/etc/pam,d/ssh)取代getty和login,然后启动shell,bash配置文件读取同上
- GUI登录方式:init进程调用显示管理器,Gnome图形界面对应的显示管理器为gdm(GNOME display manager),账户密码输入正确后,读取/etc/gdm3/Xsession,启动用户的会话。用户配置文件只加载/etc/profile 和 ~/.profile
打开终端(non-login shell)
开机之后,用户经常手动打开的shell一般是non-login shell,该shell不读取/etc/profile 和 . profile等配置文件,但可以读取用户自己的配置文件~/.bashrc
- bash设置繁琐,阶段性载入,是历史原因,系统的通用设置放在 /etc/profile,用户个人的、需要被所有子进程继承的设置放在.profile,不需要被继承的设置放在.bashrc。
- Mac OS X 使用的shell也是Bash。但是,它只加载.bash_profile,然后在.bash_profile里面调用.bashrc。而且,不管是ssh登录,还是在图形界面里启动shell窗口,都是如此。
以上是简单版本的linux开机流程
真实版的最好还是自己写个OS理解更深
微软有个叫LIMOS的前辈有个手撕OS的教程,可以帮助进一步理解
说点别的
从系统启动的流程来看,很美
给我最直接的感受就是,
由点到面的一个启动方式:
从电源键这个引爆点,逐渐蔓延,BIOS到GRUB,GRUB到OS,OS从内核到各种服务,应用程序,最终整个机器活生生的展现在你面前。
如生命一般,从一颗受精卵逐渐演化成一个四肢健全的生物。
最本质的区别在于,受精卵承载了所有分化演化信息,而电源键不同,仅仅是一种行为与动作。
真有意思……