1.Linux的组成
kernel+rootfs
kernel:进程管理、内存管理、网络管理、安全管理、文件系统管理、驱动程序
rootfs:程序和glibc
库:函数集合,function,调用接口(头文件负责描述)
过程调用:procedure ,无返回值
结果调用:function
程序:二进制文件
2.内核设计流派
单内核(monolithic kernel):Linux
把所有功能集成于同一个程序
微内核(micro kernel):Windows, Solaris
每种功能使用一个单独子系统实现
3.内核特点及组成
支持模块化:.ko(内核对象)
支持内核模块的装载和卸载
4.内核的组成
核心部件: /boot/vmlinuz-VERSION-release
伪文件系统:ramdisk
centos5:/boot/initrd-VERSION-release.img
centos6,7:/boot/initramfs-VERSION-release.img
模块文件:/lib/modules/VERSION-release
5.centos6启动流程
(1)主动读取BIOS,通过CMOS加载硬件信息 ,并进行POST,指定第一个可启动的设备
ROM:BIOS,Basic Input and Output System,保存着计算机系统最重要的基本输入输出程序,系统信息设置,开机加电自检程序
RAM:保存各项参数的设定
(2)读取第一个可启动设备MBR的引导加载程序(grub)的启动信息
<1>MBR: 446 boot loader 64:分区表 2 :55aa
BIOS通过硬件的INT13中断功能来读取MBR的
<2>Windows:ntloader 仅是启动OS
Linux: 提供菜单; 转交系统控制权; 直接指向内核文件
LILO:LInuxLOader
GRUB: GRandUnified Bootloader
primary boot loader:1st stage,1.5stage
secondary boot loader:2 stage,分区文件
bootloader的1stage是在MBR内进行的,1.5stage是再0面0磁道0扇区的后续扇区,2stage是在/boot分区上边
1stage是 寻找/boot分区的文件系统驱动
1.5stage内就是/boot分区文件系统驱动,识别/boot分区
2stage是/boot分区相关操作
/boot/grub下的stage类文件(除了stage2)都是备份
<3>ramdisk:使用缓存或缓冲来加速对磁盘上文件的访问
centos5:initrd 工具程序:mkinitrd
centos6:initramfs 工具程序:mkinitrd,dracut\
自己创建initramfs文件
mkinitrd [-v] [-with=模块名称] initrd文件名 内核版本
-v 显示mkinitrd的过程
--with=[模块名称]:模块名称指的是模块的名字,不需填写文件名
如果在救援模式下,需要切根,因为救援模式下好多库文件不存在
<4>解压缩内核到内存中,
加载可识别的所有硬件设备(以自己的功能重新检查一次硬件,不一定适用BIOS的检测结果)
加载硬件驱动
以只读方式挂载根系统
运行用户空间的第一个程序:/sbin/init
<5>内核内容
(3)内核执行init程序,获取默认运行信息
<1>init程序类型:
SysV: init, CentOS 5之前
配置文件:/etc/inittab
Upstart: init,CentOS6
配置文件:/etc/inittab, /etc/init/*.conf
Systemd:systemd, CentOS 7
配置文件:/usr/lib/systemd/system
/etc/systemd/system
<2>运行级别
0 halt(系统直接关机)
1 单用户模式下,用在系统出问题时的维护
2 类似下面的runlevel 3,但无NFS服务
3 纯文本模式
4 系统保留功能
5 字符界面
6 重新启动
切换等级:init #
查看等级: runlevel who -r
<3>/etc/inittab文件相关知识
每一行定义一种action以及与之对应的process
id : runlevel : action : process
id:代表init的主要工作选项,只是简单代表说明
runlevel:在那些等级下运行
action: initdefault:代表默认的runlevel设置值
sysinit:代表系统初始化的操作选项
ctrlaltdel:代表ctrl+alt+del三个按键是否可以重新启动
wait:代表后面设置的命令项目必须要执行完毕才能继续下面的其他操作
respawn:代表后边字段的命令可以无限制的重新启动
process:可以进行的命令
例如:
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
1:2345:respawn:/sbin/mingetty tty
x:5:resawn:/etc/prefdm -nodaemon x window 则是这行决定的
<4>/etc/init/*.conf
(4)init程序执行/etc/rc.d/rc.sysinit文件
取得网络环境与主机类型:/etc/sysconfig/network
设置显示与启动过程中的欢迎界面(textbanner)
检查根文件系统,并以读写方式重新挂载根文件系统
挂载/etc/fstab文件中定义的文件系统
设置系统时间:读入/etc/sysconfig/clock设置值 修改时区的话,把/user/share/zoneinfo/Asia /Shanghai复制到/etc/local下
激活udev和selinux
激活swap设备
初始化软件磁盘阵列、初始化lvm文件系统、、磁盘配额
加载内核相关设置:/etc/sysctl.conf
用户自定义模块加载:/etc/sysconfig/modules.conf设置
清除启动过程中产生的临时文件
将启动相关信息加载到/var/log/dmesg中
(5)启动核心的外挂模块/etc/modeprobe.conf文件
(6)init执行各个批处理文件
<1>各个运行级别脚本所在目录:
/etc/rc.d/rc 0.d
/etc/rc.d/rc 1.d
/etc/rc.d/rc 2.d
/etc/rc.d/rc 3.d
/etc/rc.d/rc 4.d
/etc/rc.d/rc 5.d
/etc/rc.d/rc 6.d
<2>脚本文件运行规则:
进入到某个运行级别的脚本目录/etc/rc.d/rc?.d
k*: k##*: ##运行次序;数字越小,越先运行;数字越小的服务,通常为依赖到别的服务
s*: S##*:##运行次序;数字越小,越先运行;数字越小的服务,通常为被依赖到的服务
s开头的文件,运行
k开头的文件,关闭
<3>chkconfig命令详解
查看服务所在级别的启动或关闭情形
chkconfig [--list] name
添加服务给chkconfig管理
SysV的的服务脚本放置于/etc/init.d
chkconfig --add name
服务脚本格式信息
#!/bin/bash
#LLLL 表示初始在哪个级别下运行 “-”表示都不启动
# LLLL mm nn mm表示启动次序 nn表示古币次序
删除
chkconfig --del name
修改制定的链接类型
chkconfig [--level levels] name <off|on|reset>
--level LLLL:省略是表示2345
图形化界面ntsysv
(7)init执行/etc/rc.d/rc.local
正常情况下,最后启动一个服务S99local没有链接至/etc/init.d下的脚本,而是指向了/etc/rc.d/rc.local脚本
不便或不需写为服务脚本放置于/etc/rc.d/init.d/目录,且又想开机时自动运行的命令,可直接放置于/etc/rc.d/rc.local文件中
(8)执行/bin/login程序,等待用户登录
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
(9)登录后以shell控制主机
BIOS加载硬件信息--》post加电自检--》加载MBR里grub信息--》stage1.5--》stage2--》initramfs--》 rootfs-->init-->/etc/inittab-->设置默认运行级别-->初始化/etc/rc.d/rc.sysinit-->/etc/rc.d/rc#.d-->/etc/rc.local
7.使用gzip -d 解压缩gz格式文件,此文件必须是.gz后缀,要不无法解压缩
8.破解centos5的root口令
(1)进入centos5 的grub界面,按a修改内核选项
(2)在命令行尾部追加1 或 S 或single,然后按enter键保存修改
(3)进入如下命令行模式,用passwd root 修改密码
(4)重新启动,用刚才修改的密码登录系统
9.编写centos5服务脚本
(1)在/root/bin写编写脚本testsrv,内容如下
(2)在/root/bin和/etc/init.d目录下分别执行chkconfig --add testsrv发现无法成功加载testsrv服务
把脚本复制到/etc/init.d下,执行上述命令,发现可以实现
(3)
在/etc/rc.d/rc3.d下查看testsrv文件时什么字母开头的
发现此命令在level 3启动等级下,是需要开启的服务,与设定一致