关键词:
一、Linux组成
1. linux:kernel+rootfs
kernrl的作用:进程管理、内存管理、网络管理、驱动程序、文件系统、安全功能
rootfs:程序和glibc
库:函数集合,function,调用接口(头文件负责描述)
过程调用:procedure ,无返回值
函数调用:function
程序:二进制执行文件
2.内核设计流派:
单内核(monolithic kernel):Linux
把所有功能集成于一个程序
微内核(micro kernel):Windows,Solaris
每种功能使用一个单独子系统实现
3.内核特点:
支持模块化:.ko(内核对象)
如:文件系统,硬件驱动,网络协议等
支持内核模块的动态装载和卸载
4.内核组成部分:
核心文件:/boot/vmlinuz-VERSION-release
ramdisk:辅助的伪根系统
CentOS 5:/booot/initrd-VERSION-release
CentOS 6,7:/boot/initramfs-VERSION-release.img
模块文件:/lib/modules/VERSION-release
二、图文简述系统启动流程
1.加载BIOS的硬件信息,获取第一个启动设备。
2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息
3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱动所有的硬件设备。
4.核型执行init程序并获取运行信息。
5.Init执行/etc/rc.d/rc.sysinit文件。
6.启动核心的外挂模块(/etc/modprobe.conf)。
7.Init执行运行的各个批处理文件(scripts).
8.Init执行/etc/rc.d/rc.local.
9.执行/bin/login程序,等待用户登录。
10.登录之后开始以Shell控制主机。
三、启动中部分过程详解
1.POST:Power-On-Self-Test,加电自检,是BIOS功能的一个主要部分。负责完成对CPU、主板、内存、硬盘子系统、显示子系统、串并行接口、键盘、CD-ROM光驱等硬件情况的检测。
1) ROM:BIOS,Basic Input and Output System,保存着有关计算机系统最重要的基本输入输出程序,系统信息设置、开机加电自检程序和系统启动自举程序等。
2) RAM:CMOS互补金属氧化物半导体,保存各项参数的设定
按次序查找引导设备,第一个有引导程序的设备为本次启动设备
2.bootloader: 引导加载器,引导程序
1)windows: ntloader,仅是启动OS
2)Linux:功能丰富,提供菜单,允许用户选择要启动系统或不同的内核版本;把用户选定的内核装载到内存中的特定空间中,解压、展开,并把系统控制权移交给内核
LILO:LInuxLOader
GRUB: GRandUnified Bootloader
GRUB 0.X: GRUB Legacy,GRUB2
2.MBR:
446: bootloader,64: 分区表, 2: 55AA
3.GRUB:
primary boot loader : 1st stage,1.5 stage
secondary boot loader :2nd stage,分区文件
4.kernel:
自身初始化:
探测可识别到的所有硬件设备
加载硬件驱动程序(可能借助于ramdisk加载驱动)
以只读方式挂载根文件系统
运行用户空间的第一个应用程序:/sbin/init
5.init程序的类型:
1)SysV: init, CentOS 5之前
配置文件:/etc/inittab
2)Upstart: init,CentOS6
配置文件:/etc/inittab, /etc/init/*.conf
3)Systemd:systemd, CentOS 7
配置文件:/usr/lib/systemd/system
/etc/systemd/system
6.ramdisk:
内核中的特性之一:使用缓冲和缓存来加速对磁盘上的文件访问
ramdisk--> ramfs提高速度
CentOS 5: initrd, 工具程序:mkinitrd
CentOS 6: initramfs,工具程序:mkinitrd, dracut
7.系统初始化
POST --> BootSequence(BIOS) --> Bootloader(MBR) --> kernel(ramdisk) --> rootfs(只读) --> init(systemd)
1.系统运行级别:为系统运行或维护等目的而设定;0-6:7个级别
0:关机
1:单用户模式(root自动登录), single, 维护模式
2: 多用户模式,启动网络功能,但不会启动NFS;维护模式
3:多用户模式,正常模式;文本界面
4:预留级别;可同3级别
5:多用户模式,正常模式;图形界面
6:重启
默认级别:3, 5
切换级别:init#
查看级别:runlevel; who -r
2.init初始化
初始运行级别(RUN LEVEL)
系统初始化脚本
对应运行级别的脚本目录
捕获某个关键字顺序
定义UPS电源终端/恢复脚本
在虚拟控制台生成getty
在运行级别5初始化X
四、系统启动相关的配置文件和脚本
1.配置文件:/etc/inittab
每一行定义一种action以及与之对应的process
id:runlevel:action:process
action:
wait: 切换至此级别运行一次
respawn:此process终止,就重新启动之
initdefault:设定默认运行级别;process省略
sysinit:设定系统初始化方式,此处一般为指定
/etc/rc.d/rc.sysinit
ca::ctrlaltdel:/sbin/shutdown -t3 -r now
id:3:initdefault:
si::sysinit:/etc/rc.d/rc.sysinit
l0:0:wait:/etc/rc.d/rc0
l1:1:wait:/etc/rc.d/rc1...
l6:6:wait:/etc/rc.d/rc6
2.其它相关配置文件
/etc/inittab:设置系统默认的运行级别
id:3:initdefault:
/etc/init/control-alt-delete.conf:设备Ctrl+ALT+delete键的动作
cat /etc/init/control-alt-delete.conf中控制Ctrl+ALT+del重启,把其关闭比较好
/etc/init/tty.conf:设备终端相关的信息
/etc/init/start-ttys.conf:设备启动终端相关的信息
/etc/init/rc.conf:设备启动文件相关的信息
/etc/init/prefdm.conf
3.系统初始化脚本:
/etc/rc.d/rc.sysinit: 系统初始化脚本
(1) 设置主机名
(2) 设置欢迎信息
(3) 激活udev和selinux
(4) 挂载/etc/fstab文件中定义的文件系统
(5) 检测根文件系统,并以读写方式重新挂载根文件系统
(6) 设置系统时钟
(7) 激活swap设备
(8) 根据/etc/sysctl.conf文件设置内核参数
(9) 激活lvm及software raid设备
(10) 加载额外设备的驱动程序
(11) 清理操作
4.关于启动脚本的一些说明
说明:rcN --> 意味着读取/etc/rc.d/rcN.d/
K*: K##*:##运行次序;数字越小,越先运行;数字越小的服务,通常为依赖到别的服务
S*: S##*:##运行次序;数字越小,越先运行;数字越小的服务,通常为被依赖到的服务
for srvin /etc/rc.d/rcN.d/K*; do
$srvstop
done
for srvin /etc/rc.d/rcN.d/S*; do
$srvstart
done
五、程序启动关闭相关命令及服务
1.chkconfig命令
查看服务在所有级别的启动或关闭设定情形:
chkconfig[--list] [name]
添加:
SysV的服务脚本放置于/etc/rc.d/init.d(/etc/init.d)
chkconfig--add name
#!/bin/bash
#LLLL 表示初始在哪个级别下启动,-表示都不启动
# chkconfig: LLLL nnnn
删除:
chkconfig--del name
修改指定的链接类型:
chkconfig[--level levels] name <on|off|reset>
--level LLLL: 指定要设置的级别;省略时表示2345
2.ntsysv命令:图形化设置系统服务启动的命令
3.xinetd管理的服务
service命令:手动管理服务
service服务:start|stop|restart|
service --status-all
瞬态(Transient)服务被xinetd进程所管理
进入的请求首先被xinetd代理
配置文件:/etc/xinetd.conf、/etc/xinetd.d/<service>
与libwrap.so文件链接
用chkconfig控制的服务:
chkconfig tftp on
4.其它一些说明:
注意:正常级别下,最后启动一个服务S99local没有链接至/etc/rc.d/init.d一个服务脚本,而是指向了/etc/rc.d/rc.local脚本
不便或不需写为服务脚本放置于/etc/rc.d/init.d/目录,且又想开机时自动运行的命令,可直接放置于/etc/rc.d/rc.local文件中
/etc/rc.d/rc.local在指定运行级别脚本后运行
可以根据情况,进行自定义修改
1:2345:respawn:/usr/sbin/mingettytty1
2:2345:respawn:/usr/sbin/mingettytty2
...
6:2345:respawn:/usr/sbin/mingettytty6
mingetty会自动调用login程序
x:5:respawn:/etc/X11/prefdm -nodaemon
六、GRUB legacy
1.CentOS 6启动流程:
POST --> Boot Sequence(BIOS) --> Boot Loader --> Kernel(ramdisk) --> rootfs--> switchroot--> /sbin/init-->(/etc/inittab, /etc/init/*.conf) --> 设定默认运行级别--> 系统初始化脚本rc.sysinit--> 关闭或启动对应级别的服务--> 启动终端
2.grub: GRandUnified Bootloader
grub 0.x: grub legacy
grub 1.x: grub2
grub legacy:
stage1: mbr
stage1_5: mbr之后的扇区,让stage1中的bootloader
能识别stage2所在的分区上的文件系统
stage2:磁盘分区(/boot/grub/)
3.配置文件:/boot/grub/grub.conf<--/etc/grub.conf
4.stage2及内核等通常放置于一个基本磁盘分区
5.grub的功用:
(1) 提供启动菜单、并提供交互式接口
a:内核参数
b: 编辑模式,用于编辑菜单
c: 命令模式,交互式接口
(2) 加载用户选择的内核或操作系统
允许传递参数给内核
可隐藏启动菜单
(3) 为菜单提供了保护机制
为编辑启动菜单进行认证
为启用内核或操作系统进行认证
6.grub的命令行接口
help: 获取帮助列表
help KEYWORD: 详细帮助信息
find (hd#,#)/PATH/TO/SOMEFILE:
root (hd#,#)
kernel /PATH/TO/KERNEL_FILE: 设定本次启动时用到的内核文件;额外还可添加许多内核支持使用的cmdline参数
例如:max_loop=100 selinux=0init=/path/to/init
initrd/PATH/TO/INITRAMFS_FILE: 设定为选定的内核提供额外文件的ramdisk;
boot: 引导启动选定的内核
7.cat /proc/cmdline 查看内核参数
8.内核参数文档:/usr/share/doc/kernel-doc-2.6.32/Documentation/kernel-parameters.txt
9.配置文件说明:/boot/grub/grub.conf
default=#: 设定默认启动的菜单项;落单项(title)编号从0开始
timeout=#:指定菜单项等待选项选择的时长
splashimage=(hd#,#)/PATH/TO/XPM_FILE:菜单背景图片文件路径
hiddenmenu:隐藏菜单
password [--md5] STRING: 启动菜单编辑认证
title TITLE:定义菜单项“标题”, 可出现多次
root (hd#,#):grub查找stage2及kernel文件所在设备分区;为grub“根”
kernel /PATH/TO/VMLINUZ_FILE [PARAMETERS]:启动的内核
initrd/PATH/TO/INITRAMFS_FILE: 内核匹配的ramfs文件
password [--md5] STRING: 启动选定的内核或操作系统时进行认证
10.密码生成工具:grub-md5-crypt命令
11.破解root口令:
启动系统时,设置其运行级别1
进入单用户模式:
(1) 编辑grub菜单(选定要编辑的title,而后使用e命令);
(2) 在选定的kernel后附加
1, s, S或single都可以;
(3) 在kernel所在行,键入“b”命令
(4)进行密码的重新设置
12.安装grub:
(1) grub-install
安装grub stage1和stage1_5到/dev/DISK磁盘上,并复制GRUB相关文件到DIR/boot目录下
grub-install --root-directory=DIR /dev/DISK
(2) grub
grub> root (hd#,#)
grub> setup (hd#)
本文出自 “提着酱油瓶打醋” 博客,请务必保留此出处http://sauce.blog.51cto.com/11880696/1853768
centos5,6的启动流程
一般情况下X86架构平台的启动流程: 1.POST:Power-onSelfTesting,加电自检 保证硬件的正常操作,从而能够正确的使用各种硬件 2.BootSequence(程序的启动顺序) 决定到底从何种设备加载操作系统内核;通常可选的设备... 查看详情
centos5,6启动流程
Linux系统的启动分为4个阶段,每个阶段都会完成不同的启动任务。其主要流程可以概括为: 1.POST:Power-OnSelfTest,加电自检 2.BootSequence:启动顺序 3.内核 4.Init &... 查看详情
centos5,6启动流程
centos5,6启动流程:1post2grub1)mbr446stage12)stage1.5mbr后面的27sectors3)/boot/grubstage2grub-install--root-directory=/mnt/sysimage/dev/sda3/boot/vmlinuz4/boot/initramfs5mount/6/sbin/init/etc/inittabN7/etc/rc 查看详情
centos5/6启动过程略解
CentOS(RHEL)系列操作系统的启动流程:IntelX86兼容架构 系统初始化流程(内核级别)POST-->BootSequence(BIOS)-->BootLoader(MBR)-->kernel(内核核心文件只能放置在基本分区上)[-->ramdisk]-->rootfs(read-only)-->/sbin/init 查看详情
centos系统启动流程
...将以CentOS发行版为例来介绍Linux系统的启动流程,因为在CentOS5、CentOS6以及CentOS7使用的初始化程序init各不相同,虽然CentOS6和CentOS7都有向后兼容,但在工作机制上仍有一些差异,因此以下主要介绍CentOS5/6系 查看详情
centos5.6u盘启动安装笔记
一、制作启动安装U盘用UltraISO打开CentOS5.6镜像点击启动->写入硬盘映像->格式化,格式化成fat32格式点击启动->写入硬盘映像->写入打开U盘,删掉除isolinux和images外的所有文件和目录将CentOS5.6镜像拷贝到U盘根目录二、CentOS5... 查看详情
编写centos5,6下的服务脚本
概述:CentOS5和6下的服务启动时,使用的命令都是service服务名start方式启动,其实service命令也是调用了/etc/init.d/下的脚本,下面请看具体步骤实验步骤: 首先准备好服务脚本,下面这一段代码是我之前写的,其... 查看详情
启动和内核管理
一、启动和内核管理1)CentOS5和6的启动流程2)服务管理 3)Grub管理 4)自制Linux5)启动排错 6)编译安装内核二、linux组成 Linux:kernel+rootfs kernel:进程管理、内存管理、网络管理、驱动程序、文件系统、安全功能... 查看详情
启动和内核管理
一、启动和内核管理1)CentOS5和6的启动流程2)服务管理 3)Grub管理 4)自制Linux5)启动排错 6)编译安装内核二、linux组成 Linux:kernel+rootfs kernel:进程管理、内存管理、网络管理、驱动程序、文件系统、安全功能... 查看详情
centos系统启动流程
...的作用。因为CentOS7改动较大,所以下面的内容只是针对CentOS5和6来说的。下面进入正题。启动流程: 第一步:POST加电自检 此过程的就是为了检测一下外界的硬件设备是否能够正常运行,如CPU,内存设备,硬盘等等... 查看详情
centos5/6启动过程
CentOS系列的操作系统的架构类型是X86架构,其内核实现方式是单内核,单内核的意义的在于他对外表现为一个应用程序即一个进程启动整个系统,所有的功能都集中在这一个进程里;而windows系列的内核实现方式是微内核,... 查看详情
centos系统启动流程(代码片段)
...用的是systemd初始化进程改动比较大,使用这里主要介绍centos5和6的开机启动流程。先上一个大致的启动流程图第一步:POST加电自检 加电自检是BIOS功能的一部分,负责CPU,主板,内存等硬件的自检工作。第二步:BootLoader... 查看详情
centos5.x开机启动流程
650)this.width=650;"title="CentOS5开机流程.jpg"src="https://s5.51cto.com/wyfs02/M01/07/41/wKiom1nGCrWy3ANDAAnPiturAgQ491.jpg"alt="wKiom1nGCrWy3ANDAAnPiturAgQ491.jpg"/> 查看详情
系统启动和内核管理
系统启动和内核管理CentOS5和6的启动流程 服务管理Grub管理 自制Linux 启动排错 编译安装内核Linux组成Linux:kernel+rootfs kernel: 进程管理、 内存管理、 网络管理、 驱动程序、 文件系统、 ... 查看详情
centos启动流程及grubinitramfs修复
...rub修复initramfs修复boot破坏修复1.centos启动流程 在centos5和6中启动流程如下:(1).POST加电自检硬件加电自检程序(安装在CMOS中的BIOS程序)BIOS负责检测硬件设备是否正常运行,如cpu、内 查看详情
centos5&6的启动过程
CentOS-6系统启动过程:按下开关按钮给服务器供电BIOS自检操作 检查硬件是否存在异常(显示logo画面)MBR引导系统 硬盘启动系统 光驱启动系统 U盘启动系统 网络方式自启动... 查看详情
centos567启动具体流程(代码片段)
CentOS5、6系统的启动流程基于IntelX86架构平台的系统启动流程:1.POST:Power-OnSelfTesting,加电自检;CMOS:在这里面有一个EPROM,可擦写可编程的只读存储器;在这里面保存了一小段程序叫做BIOS程序,全称为BasicInputOutputSystem,基本... 查看详情
centos5内核是啥版本的
CentOS5各版本内核如下:CentOS5:2.6.18-8CentOS5.1:2.6.18-53CentOS5.2:2.6.18-92CentOS5.3:2.6.18-128CentOS5.4:2.6.18-164CentOS5.5:2.6.18-194CentOS5.6:2.6.18-238CentOS5.7:2.6.18-274CentOS5.8:2.6.18-308CentOS5.9:2.6.18-348CentOS5.10:2.6.18-371参考技术A硫酸殖屏矫健... 查看详情