• linux开机启动及运行级别、root密码丢失、单用户模式只读的处理方法


    linux系统启动大致步骤如下:

     加电自检-->根据BIOS中的设置从指定的设备启动-->找到设备MBR中的bootloader引导启动系统-->启动kernel-->启动init进程


    linux系统启动流程可细分为10步:

    加载BIOS-----读取MBR------Boot Loader---加载内核---用户层init依据inittab文件来设定运行等级/sbin/init---init进程执行rc.sysinit-----启动内核模块----执行不同运行级别的脚本程序---执行/etc/rc.d/rc.local----执行/bin/login程序,进入登录状态。

    1加载BIOS(basic inputoutput system   基本输入/出系统)

    你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它。这是因为BIOS中包含了CPU的相关信息、设备启动顺序信息、硬盘信息、内存信息、时钟信息、PnP特性等等。在此之后,计算机心里就有谱了,知道应该去读取哪个硬件设备了。

    2 .读取MBR(Master Boot Record 主引导记录)

    众所周知,硬盘上第0磁道第一个扇区(最外面的磁道)被称为MBR,也就是Master Boot Record,即主引导记录,它的大小是512字节,里面存放了预启动信息、分区表信息。系统找到BIOS所指定的硬盘的MBR后,就会将其复制到物理内存中。其实被复制到物理内存的内容就是Boot Loader,而具体到你的电脑,那就是lilo或者grub了。

    3.Boot Loader(启动加载器)

     就是在操作系统内核运行之前运行的一段小程序。通过这段小程序,我们可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用操作系统内核做好一切准备。

    Boot Loader有若干种,其中GrubLilospfdisk是常见的Loader

    系统读取内存中的grub配置信息,并依照此配置信息来启动不同的操作系统。

    4.加载内核

    根据grub设定的内核映像所在路径,系统读取内存映像,并进行解压缩操作。此时,屏幕一般会输出“Uncompressing Linux”的提示。当解压缩内核完成后,屏幕输出“OK, booting the kernel”。系统将解压后的内核放置在内存之中,并调用start_kernel()函数来启动一系列的初始化函数并初始化各种设备,完成Linux核心环境的建立。至此,Linux内核已经建立起来了,基于Linux的程序应该可以正常运行了。先加载Initramfs-2.3..是内存映像文件.  再加载Vmliunz-2.6..是内核文件.都在boot目录下

    5.启动第五步:用户层init依据inittab文件来设定运行等级/sbin/init

    内核被加载后,第一个运行的程序便是/sbin/init,该文件会读取/etc/inittab文件,并依据此文件来进行初始化工作。

    其实/etc/inittab文件最主要的作用就是设定Linux的运行等级,其设定形式是idrunlevelsactionprocess

    如“:id:5:initdefault:”,这就表明Linux需要运行在等级5上。

    id:它是每个登记项的标识符,用于唯一标识每个登记项,不能重复 runlevels:系统的运行级别,表示processaction要在哪个级别下运行,该段中可以定义多个运行级别,各级别之间直接写不用分隔符;如果为空,表示在所有的运行级别运行。Linux的运行级别有:

      0:表示关机

      1:表示单用户模式,在这个模式中,用户登录不需要密码,默认网卡驱动是不被加载,一些服务不能用。

      2:表示多用户模式,NFS服务不开启

      3,表示命令行模式

      4,这个模式保留未用

      5,表示图形用户模式

      6,表示重启系统

    6.启动第六步--init进程执行rc.sysinit.

    在设定了运行等级后,Linux系统执行的第一个用户层文件就是/etc/rc.d/rc.sysinit脚本程序,它做的工作非常多,包括设定PATH、设定网络配置(/etc/sysconfig/network)、启动swap分区、设定/proc等等。

    7.启动第七步--启动内核模块

    具体是依据/etc/modules.conf文件或/etc/modules.d目录下的文件来装载内核模块。

    8.启动第八步--执行不同运行级别的脚本程序

    根据运行级别的不同,系统会运行rc0.drc6.d中的相应的脚本程序,来完成相应的初始化工作和启动相应的服务。

    具体位置:/etc/rc.d/

    [root@lbg test]# cd /etc/rc.d

    [root@lbg rc.d]# ls

    init.d  rc0.d  rc1.d  rc2.d  rc3.d  rc4.d  rc5.d  rc6.d  rc.local

    其中rc*.d里面其实都是软链接文件,指向的是init.d里关于服务的启停脚本.

    [root@lbg rc.d]# cd rc5.d/

    [root@lbg rc5.d]# ll

    lrwxrwxrwx. 1 root root 20 Oct  1 11:54 K50netconsole -> ../init.d/netconsole

    lrwxrwxrwx. 1 root root 17 Oct  1 11:54 S10network -> ../init.d/network

    [root@lbg rc5.d]# cd ../init.d/

    [root@lbg init.d]# ll

    -rw-r--r--. 1 root root 17500 May  3  2017 functions

    -rwxr-xr-x. 1 root root  4334 May  3  2017 netconsole

    -rwxr-xr-x. 1 root root  7293 May  3  2017 network

    -rw-r--r--. 1 root root  1160 Aug  5  2017 README

    说明:/etc/rc.d/rc5.d里软链接如果是k开头,则是开机不启动(kill),s开头,则是开机自启动(start).

    init.d里是关于服务的启停脚本.

    9.启动第九步--执行/etc/rc.d/rc.local

    rc.local就是在一切初始化工作后,Linux留给用户进行个性化的地方。你可以把你想设置和启动的东西放到这里。

    10.启动第十步--执行/bin/login程序

    进入登录状态.此时,系统已经进入到了等待用户输入usernamepassword的时候了,你已经可以用自己的帐号登入系统了。漫长的启动过程结束了,一切都清静了.后面就是/etc/nsswitch/conf名字服务,再到/etc/passwd里根据对应用户启动默认的shell.



    root密码忘了的处理方法:

     开机按上下键进入:(选择操作系统)

    进入下一步(edit

    选到kernel,再按e.

    输入 空格 1 回车键.

    跳回上步页面,依旧选择kernel,输入b(boot),回车.就可进入单用户模式,再改密码(passwd)后reboot即可.

     

    进入单用户模式操作系统依旧是只读的处理方法:

     /etc/fstab.里写错了,进入单用户模式依旧是只读,没法处理.

    处理方法是:进入单用户模式,然后 mount -o remount,rw /     --重新挂载根目录,权限是rw.    --o,option.

     

  • 相关阅读:
    2017普及组D1T3 洛谷P3956 棋盘
    2017提高组D1T1 洛谷P3951 小凯的疑惑
    Title
    Title
    Title
    Title
    Title
    Title
    Title
    Title
  • 原文地址:https://www.cnblogs.com/lbg-database/p/10109963.html
Copyright © 2020-2023  润新知