Linux系统的启动过程
计算机的启动过程当计算机打开电源后,首先是BIOS开机自检,按照BIOS中设置的启动设备(通常是硬盘)来启动。硬件自检完成后,BIOS把控制权转交给下一阶段的启动程序。这时,BIOS需要知道,”下一阶段的启动程序”具体存放在哪一个设备。也就是说,BIOS需要有一个外部储存设备的排序,排在前面的设备就是优先转交控制权的设备。这种排序叫做”启动顺序”(Boot Sequence)。打开...
计算机的启动过程
- 当计算机打开电源后,首先是BIOS开机自检,按照BIOS中设置的启动设备(通常是硬盘)来启动。硬件自检完成后,BIOS把控制权转交给下一阶段的启动程序。
这时,BIOS需要知道,”下一阶段的启动程序”具体存放在哪一个设备。也就是说,BIOS需要有一个外部储存设备的排序,排在前面的设备就是优先转交控制权的设备。这种排序叫做”启动顺序”(Boot Sequence)。
打开BIOS的操作界面,里面有一项就是”设定启动顺序”。
找到这个启动顺序只想的设备之后,就会找到这个硬盘上的第一个扇区,也就是BIOS通常是转向第一块硬盘的第一个扇区,即主引导记录(MBR)。
2. 启动BootLoader,这个bootloader主要在Linux上是Grub,其主要功能是载入内核。可以通过以下命令,进行查看grub的配置文件:
vim /boot/grub/grub.conf
grub> root (hd0,0) 设置根目录为第一硬盘的第一个分区
kernel 内核文件的版本
initrd 表示镜像文件
- 内核的主要包括各种各样的硬件驱动,在操作系统层面上对各个硬件设备进行扫描
- 扫描完成之后,就会启动init进程,这个进程很特殊,他的PID永远都是1,所有其他的进程都是它的子进程。父进程和子进程的关系是,父进程关闭,子进程必须关闭,否则就会变成孤儿进程,孤儿进程就会自动把自己的父进程指向init 进程。子进程关闭,父进程不知道,但是父进程还和子进程保持联系,那么就变成了僵尸进程。
- init进程,就会读取他的配置文件,/etc/inittab,配置文件。这个配置文件也可以用man指令来进行获取帮助。
- 在 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)
前面提到,七种预设的”运行级别”各自有一个目录,存放需要开机启动的程序。不难想到,如果多个”运行级别”需要启动同一个程序,那么这个程序的启动脚本,就会在每一个目录里都有一个拷贝。这样会造成管理上的困扰:如果要修改启动脚本,岂不是每个目录都要改一遍?
Linux的解决办法,就是七个 /etc/rcN.d 目录里列出的程序,都设为链接文件,指向另外一个目录 /etc/init.d ,真正的启动脚本都统一放在这个目录中。init进程逐一加载开机启动程序,其实就是运行这个目录里的启动脚本。
- 接下来,就可以进行用户登陆了。
- rc执行完毕后,返回init。这时基本系统环境已经设置好了,各种守护进程也已经启动了。
init接下来会打开6个终端,以便用户登录系统。在inittab中的以下6行就是定义了6个终端:
1:2345:respawn:/sbin/mingetty tty1
2:2345:respawn:/sbin/mingetty tty2
3:2345:respawn:/sbin/mingetty tty3
4:2345:respawn:/sbin/mingetty tty4
5:2345:respawn:/sbin/mingetty tty5
6:2345:respawn:/sbin/mingetty tty6
同时它会显示一个文本登录界面,这个界面就是我们经常看到的登录界面,在这个登录界面中会提示用户输入用户名,而用户输入的用户将作为参数传给login程序来验证用户的身份。
注意:
第一个问题:如果,root用户密码忘了,如何改?
这个就可以进入单用户模式,也就是运行级别1. 就可以进行更改密码
-第二个问题:如何检查自己的软件时钟和硬件时钟?
date就是软件时钟命令
hwclock就是硬件时钟命令
更多推荐
所有评论(0)