内核启动流程

系统启动流程(1)
  
    pc:os(linux)
  
     POST(加电自检)-->BIOS (Boot sequence)(决定到哪里有启动操作系统的顺利)--MBR(bootloader ,446bit)

    -->Kernel  (文件系统、进程管理、内存管理、网络管理、安全功能、驱动程序)-->initrd
    --/sbin/init (用户空间进程的管理)[启动系统模块,与相关的硬件信息的初始化文件 /etc/rc.d/rc.sysinit-->启动系统中所需的各项服务/etc/rc.d/rc]
    

    /etc/rc.d/ec.loacl   可以自定义脚本程序在这里,开机启动就可以启动的服务
    
       这些脚本的配置文件都是放在、/etc/sysconfig

       系统自定义的设备与模块对应文件  :   /etc/modprobe.conf

    加载流程:
              1、通电自检,加载BIOS的硬件信息与进行自我测试,并根据设置取得第一个可启动的设备;
              2、读取并执第一个启动设备内MBR的boot loader(即是grup,spfdisk等程序)
              3、依据boot loader的设置加载Kernel,Kernel会开始检测硬件与加载驱动程序
              4、在硬件驱动成功后,Kernel会主动调用init进程,而init会取得run-level等信息
              5、init执行/etc/rc.d/rc.sysinit文件来准备软件执行的操作环境(如网络、时区等信息)
              6、init执行run-revel的各个服务的启动
              7、init执行/etc/rc.d/rc.local文件
              8、init执行终端模拟程序mingetty来启动login进程,最后就等用户登录

     运行级别:启动的服务不同
          运行级别:0-6
               0:halt  关机
               1:single user mode   单用户模式 ,直接以管理员身份切入,不用密码(维护模式)1 s S singer
               2:multi user mode, no nfs文件系统   多用户模式
               3:multi user mode,多用户命令模式
               4:reseved 保留级别
               5:multi user mode   多用户界面模式
               6:重启 
         
     运行级别的配置文件  /etc/inittab

  详解启动过程
    bootloader(属于MBR)
          linux    LILO:linux LOader
                   GRUB:
                   stagel:MBR
                   stagel1.5:
                   stagel:/boot/grub/

  grub  的配置文件
greb.conf
 default=0     设定默认启动的title的编号,从0开始
timeout=5      等待用户选择的超时时长,单位为妙
splashimage=(hd0,0)/grub/splash.xpm.gz   grub 的背景图片
hiddenmenu    隐藏菜单
password 明文
password  --md5  md5格式加密的           命令行grub-md5-crypt  可以直接产生MD5密码
title CentOS 6 (2.6.32-504.el6.x86_64)     内核标题或操作系统名称,字符串可以自由修改
        root (hd0,0)    内核文件所在的设备,对Grub而言,所有类型硬盘一律为hd: 表示第几个磁盘,最后的0表示对应磁盘的分区
        kernel /vmlinuz-2.6.32-504.el6.x86_64 ro SFONT=
        initrd /initramfs-2.6.32-504.el6.x86_64.img

   查看运行级别:
    runlevel    who -r  
  
   查看内核:
       uname -r   显示内核版本号
   
   安装grub  stagel:
     #grub
     grub >root  (hd0,0)
     grub >set (hd0)
     安装grub第二种方式:
     # grub-install --root-directory=/
Kernel初始化的过程中:
    1:设备探测
    2:驱动初始化(从initrd文件中装载驱动模块)
    3:以只读方式挂载根文件系统
    4:装载第一个进程init (pid :1)


     /sbin/init:   读取的文件(/etc/inittab)
         upstart
        
         id:标识符
         runlevels:运行在哪个级别;
         action:在什么情况下执行此行;
         process:要运行进程;
     
         si :sysinit (系统初始化)
   
          initdefault:设定默认运行级别
          sysinit:系统初始化
          wait:等待级别切换完成
         

      /etc/rc.d/sysinit完成的任务:
        1、激活udev和selinux;
        2/根据/etc/sysctl.conf文件,来设定内核参数;
        3、设定时钟时钟;
        4、装载键盘映射;
        5:启用交换分区;
        6:设置主机名;
        7:根文件系统检测,并以读写方式重写挂载
        8:激活RSID和LVM设备
        9:启用磁盘配额;
        10:根据/etc/fstab,检查并挂载其它文件系统;
        11:清理过期的锁和PID文件;




     内核设计的风格:
        单内核:把所有的功能多做成一个内核,Linux,仅支持轻量级进程(线程)
                 核心:KO(Kernel object)

        微内核:window,支持多线程


      chroot:chroot  /PATH/TO


核心:/boot/vmlinuz-version
内核模块(ko):/lib/modules/version/
内核设计:
      单内核     Linux   模块化设计     内核很小,吧基本的功能装载模块
   
      
      微内核     模块化设计  
 
装载模块:
       indmod
       www.kernel.org
     用户空间访问,监控内核的方式:
 /proc,/sys

  伪文件系统
   /proc/sys :在此目录中的文件是可以读写的,
   /sys :某些文件可写
  
设定内核参数值的方法:
   echo VALUE > /proc/sys/...
   sysctl -W kernel.hostname=

内核参数脚本: /etc/sysctl.conf  


内核模块管理 ;
    列出内核装载了哪些模块      command:lsmod
    管理模块:    modprobe   MOD_NAME:装载某个模块
                  modprobe  -r   MOD_NAME   卸载某个模块
               
     查看模块的具体信息   modinfo   COM_NAME  
       
      insmod  /PATH/TO/MOD-NAME_FILE    装载模块,   一定要指定模块的路径
      
         remod MOD_NAME    移除某个模块


      depmod   /PTAH/TO/MODLIES_STR      依靠关系


    内核中的 功能除了核心功能之外,在编译的时候,大多功能会有三种选择:
     1、不适用此功能
     2、编译成内核模块
     3、编译进内核
     
  如何手动编译内核:
    
     查看内核版本:   uname -r    
     


你可能感兴趣的:(linux,操作系统,sequence,配置文件,网络管理)