CentOS6启动流程

CentOS 6 启动流程 | root密码重置 | 添加系统服务

一、CentOS 6 启动流程:

    1)POST加电自检

        Power-On-Self-Test,主板在接通电源后,系统首先由BIOS程序来对对CPU、主板、内存、硬盘子系统、显示子系统、串并行接口、键盘、CD-ROM光驱等硬件情况的检测。

        自检中如发现有错误,将按两种情况处理:对于严重故障则停机,对于非严重故障则给出提示或声音报警信号,等待用户处理。

        主板上 ROM:保存了BIOS程序    RAM:保存各项参数设定

        BIOS按设定次序查找引导设备,第一个有引导程序的设备为本次启动设备

    2)读取 MBR

        读取第一个启动设备MBR中的bootloader(前446字节),CentOS 6为grub程序,bootloader空间有限仅保存了grub第一阶段stage1。

    3)引导加载程序 GRUB

        stage1:存在于MBR前446字节中,加载stage1_5,stage2,initramfs*.img

        stage1_5:在MBR之后62个扇区中,保存了必要的文件系统驱动程序等,让stage1能识别stage2所在分区上的文件系统;

        stage2:提供菜单交互接口,让用户以选项方式加载内核、改变参数、修改选项,获取grub.conf以及menu.lst等文件的内容,可提供认证保护机制。

    4)加载内核

        自身初始化:

        探测可识别到的所有硬件设备

        加载硬件驱动程序(可能借助于ramdisk加载驱动)

    内核无法识别硬盘上各驱动程序所在的设备,借助已识别的boot分区中的initramfs-VERSION-RELEASE.img文件(一个压缩的小型根目录,包含启动阶段必须的驱动模块,可执行文件和启动脚本),

将其挂载为临时根目录,执行启动脚本,加载真实文件系统以挂载真正的根目录并切换根目录。

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

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

    5)启动 init

        内核加载完毕,运行init程序,系统启动的控制权移交给init进程

        init进程是所有进程的父进程,它会读取配置文件/etc/inittab,进行以下工作:

        1.执行系统初始化脚本(/etc/rc.d/rc.sysinit),对系统进行基本的配置,以读写方式挂载根文件系统及其它文件系统,进行运行级别的确定及相应服务的启动;
        2.确定启动后进入的运行级别,共7个,默认3,5;
        3.执行/etc/rc.d/rc,定义服务启动的顺序是先K后S,具体的每个运行级别的服务状态是放在/etc/rc.d/rc#.d(#=0~6)目录下,所有的文件均链接至/etc/init.d下的相应文件。
        4.有关key sequence的设置
        5.有关UPS的脚本定义
        6.启动虚拟终端/sbin/mingetty 
        7.在运行级别5上运行X

    系统初始化:

   POST–>BootSequence(BIOS)–>Bootloader(MBR)–>kernel(ramdisk)–>rootfs–>/sbin/init

    在rc.loacl中添加自定义开机运行脚本:

        正常级别下,最后启动的一个服务S99local没有链接至/etc/init.d下的某脚本,而是链接至了/etc/rc.d/rc.local (/etc/rc.local)脚本;因此,不便或不需写为服务脚本的程序期望能开机自动运行时,可直接放置于此脚本文件中。



二、root密码重置

    1.进入单用户模式

        开机时键入 e ,进入grub菜单页面,键入 a,在kernel行尾添加1,s,S,sigle任意一个,即单用户模式,回车启动系统

    2.直接用passwd更改密码

        进入命令行后直接键入passwd即可更改密码


三、添加系统服务

    CentOS 6中系统服务脚本都放在/etc/init.d目录下,当用户使用service命令对某个服务进行操作时,实际上是调用了该目录下的脚本,所以我们也可以添加自己的服务脚本。

    1.编写服务脚本

        前三行基本格式:vi testsrv

            #!bin/bash

            #chkconfig: 35 91 09

            #description:testsrv..

    脚本第一行为shellbang

    第二行chkconfig后跟3个数,第1个数为需启动的级别,35表运行级别为3或5时启动;第2个数为启动优先级,数字越大优先级越低,越在后面启动;第3个数为关闭优先级,数字越小优先级越高,越先关闭;

    一般后两个数之和为100,被依赖性不高的服务可以后启动,后启动的先关闭;后两位若为一位数(0-9),应写成08格式

    第三行为描述信息,可根据需要修改。

        服务脚本应能识别基本的参数 [ start|stop|restart|status ]

        将写好的脚本放在/etc/init.d目录下

    2.添加为系统服务

        chkconfig –add /etc/init.d/testsrv

        该命令将脚本添加为系统服务,让chkconfig可以管理它,并在每个运行等级启动服务(/etc/rc.d/rc#.d)目录下创建对应符号链接K/S入口,K开头表关闭,S开头表启动

    3.服务操作

        chkconfig –level 35 testsrv on    修改服务的默认启动等级

        service testsrv restart    重启服务

作业

1、每周2, 4, 7备份/var/log/messages文件至/logs目录中,文件名形如“messages-yyyymmdd”

* * * * * /bin/cp /var/log/messages /logs/messages-`date +\%Y\%M\%d`

2、每两小时取出当前系统/proc/meminfo文件中以S或M开头的信息追加至/tmp/meminfo.txt文件中

* */2 * * * grep "^[SM]" /proc/meminfo >>/testdir/meminfo.txt

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

(0)
JasperJasper
上一篇 2016-09-08 18:55
下一篇 2016-09-08 18:55

相关推荐

  • 用户和组——Linux基本命令(10)

    1.     用户和组的配置文件 Linux用户和组的主要配置文件: /etc/passwd:用户及其属性信息(名称、UID、主组ID等) /etc/group:组及其属性信息 /etc/shadow:用户密码及其相关属性 /etc/gshadow:组密码及其相关属性   2. /etc/passwd 在Li…

    2017-07-22
  • 网络配置——路由配置实验

    一、实验环境: 4台虚拟主机,2台CentOS6.8主机做了R1路由器和PC1主机,2台CentOS7.2主机做了R2路由器和PC2主机,4台主机工作在桥接模式下 实验拓扑图: 二、网络配置: ·PC1的网卡配置; ·PC2的网卡配置; ·R1的网卡配置; ·R2的网卡配置; ·启用路由      &nbsp…

    Linux干货 2016-09-07
  • Linux基础学习总结(一)

    一、计算机的组成与功能 二、Linux的版本 三、Linux的哲学思想 四、Linux基础命令(一) 五、Linux帮助信息 六、Linux目录结构

    Linux干货 2016-09-20
  • 1017练习题

    1017练习题 作业 10月17日 柴震 1.生产环境发现一台服务器系统时间产生偏差,造成服务异常,请帮忙校正。 hwclock 查看硬件是否准确,如准确无误,可以使用hwclock -s以硬件时间为准。 或者使用ntpdate命令指定一台NTP服务器,进行同步。 2.生产有一个数据同步脚本需要执行很长时间,怎样做到无人值守,在…

    Linux干货 2016-10-18
  • 8-10 bash变量浅谈

    8-10 作业 一、脚本 1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。 2、编写脚本/root/bin/backup.sh,可实现每日将/etc/目录备份到/root/etcYYYY-mm-dd中 3、编写脚本/root/bin/disk.…

    Linux干货 2016-08-15
  • 第十一周作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 一次通信加密过程: 发送方: 1.使用单向加密算法提取生成数据特征码; 2.使用自己的私钥加密特征码附加在数据后面; 3.生成用于对称加密的临时密钥; 4.用此临时密钥加密数据和已经使用私钥加密后的特征码; 5.使用接受方的公钥加密此临时密钥,附加在对称密钥后的数据后方; 接受方: 1.使用自己的私钥解密加密的…

    2017-10-02

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-10 09:57

    每周2, 4, 7:表示为 * * * * */2,4,7