菜鸟学Linux 第033篇笔记 bootloader,inittab
Linux 系统自启动流程
PC OS (Linux)
POST-->BIOS(Boot Sequence)-->MBR(bootloader,446byte),GPT-->Kernel
-->initrd-->ROOTFS /sbin/init(/etc/inittab)
运行级别 (启动的服务不同)
运行级别:0-6
0 halt
1 single user mode 直接以管理员身份切入 s,S,single
2 multi user mode, no NFS
3 multi user mode, text mode
4 reserved
5 multi user mode, graphic mode
6 reboot
详解启动过程
bootloader(MBR)
LILO LInux LOader(早期,适合嵌入式系统)
GRUB GRand Unified Bootloader
stage1 MBR
stage1_5 识别文件系统
stage2 /boot/grub/
bootloader 有446字节最多
/etc/grub.conf 文件格式
default=0 默认启动title
timeout=5 等待用户选择的超时时长
splashimage= 背景图片
hiddenmenu 隐藏菜单
password myroot
password --md5 此处为进入编辑grub时输入密码
title 内核标题,或操作系统名称字符串,可自由修改
root (hd0,0) 内核文件所在的设备:对grub而言,所有类型硬盘一律hd
第一个0 表示第几个磁盘,第二个对应硬盘分区
kernel 内核路径和传递给内核的参数 /proc/cmdline
initrd ramdisk文件路径
password --md5 放在此处则进入内核需要输入密码
内核设计风格
RedHat, SUSE
核心 动态加载 内核模块
内核 /lib/modules/"内核版本号命名的目录"/
vmlinuz-2.6.32
/lib/modules/2.6.32/
RedHat5 ramdisk-->initrd
RedHat6 ramfs-->initramfs
单内核 Linux (LWP)
核心 KO (kernel object)
微内核 windows Solaris(多线程)
Jail
chroot (run command or interactive shell with special root directory)
chroot /test/vrroot or /test/vrrot/bin/bash
ldd /path/Binary_file 显示二进制文件所依赖的共享库
Command
yum install gimp 一个图形编辑软件
使用Xshell远程软件可以启动远程的图形界面gimp &
grub-md5-crypt 使用md5给生成grub密文
runlevel Print previous and current SysV runlevel
who -r display runlevel
uname ( print system information)
-r, --kernel-release
print the kernel release
dd if=/dev/zero of=/dev/sda count=1 bs=400 破坏硬盘的bootloader
修复grub
第一种:
#grub
grub>root (hd0,0)
grub> set (hd0)
第二种:
#grub-install --root-directory=/path/boot's parent /dev/hda
给其它硬盘安装grub
1.将硬盘格式化好之后,挂载到一个以/mnt/boot目录下该硬盘的你目录必须是boot
2.使用命令grub-install --root-directory=/mnt /dev/sd(a,b,c...)
前边的root-directory 必须选用boot的父目录
3.完成后会在该硬盘下生成一个grub的文件夹,打开后里边有文件
4.手动生成一个grub.conf配置文件在grub目录下vim /mnt/boot/grub/grub.conf
编辑该配置文件
default=0
timeout=5
title mylinux(name)
root (hd0,0)
kernel /vmlinuz-2.6.18-308.el5
initrd /initrd-2.6.18-308.el5.img
注意以上两个的版本是一样的,,这样grub就制作完成了
如果grub.conf配置文件丢失,系统启动时会进入grub模式,只要知道内核在哪里就可以启动
如果硬盘多可以在grub模式下输入find (hd0,0)/按Tab来查看此硬盘下所有的内核文件
查找到后执行
grub> root (hd#,#)
grub> kernel /vmlinuz-2.6.18-308.el5
grub> initrd /initrd-2.6.18-308.el5.img
grub> boot
即可启动该Linux系统#号表示要对应具体的第几块硬盘,第几个分区
Kernel初始化的过程:
1、设备探测
2、驱动初始化(可能会从initrd (initramfs)文件中装载驱动模块)
3、以只读挂载根文件系统
4、装载第一个进程init (PID:1)
/sbin/init: (/etc/inittab) (古老)
RedHat6 upstart ubuntu, d-bus, event-driven
systemd 并行
/etc/inittab文件下的定义
# Default runlevel. The runlevels used by RHS are:
id:5:initdefault: 格式含义
id 标识符
runlevels 在哪个级别运行此行
action 在什么情况下执行此行
initdefault 设定默认运行级别
sysinit 系统初始化
wait 等待级别切换至此级别时执行
respawn 一旦程序终止,会重新启动该程序
process 要运行程序
# System initialization.
si::sysinit:/etc/rc.d/rc.sysinit
/etc/rc.d/rc.sysinit完成的任务
1、激活udev和selinux
2、根据/etc/sysctl.conf文件,来设定内核参数
3、设定时钟
4、装载键盘映射
5、启用交换分区
6、设置主机名
7、根文件系统检测,并在没有错误之后,以读写方式重新挂载
8、激活RAID和LVM设备
9、启用磁盘配额
10、根据/etc/fstab,检查并其它文件系统
11、清理过期的锁和PID文件
/etc/rc.d/init.d /etc/init.d
服务类脚本
start
stop
SysV: /etc/rc.d/init.d
start|stop|restart|status
reload|configtest
脚本中的
# chkconfig: 345 26 74
第一组 runlevels
第二SS start 优先次序
第三KK kill 次序
当chkconfig命令来为此脚本在rc#.d目录创建链接时,
runlevels表示默认创建为S*开头的链接如果为-则表示所有级别,
除此之外的级别默认创建为K*开关的链接
S后面的启动优先级为SS所表示的数字,K后面的优级为KK所表示的数字
# description:
用于说明此脚本的简单功能\,续行
chkconfig命令 updates and queries runlevel information for system services
--list 列出所有独立守护服务的启动设定
先将服务脚本cp到/etc/rc.d/init.d/目录下
chkconfig --add SERVICE_NAME 添加服务链接到/etc/rc.d/rc#.d目录下
chkconfig --add SERVICE_NAME 删除/etc/rc.d/rc#.d目录下的服务链接
chkconfig --level RUNLEVEL SERVICE_NAME {on|off}
如果省略级别指定,默认为2345级别
/etc/rc.local /etc/rc.d/rc.local
系统最后启动的一个服务,准确说,应该执行的最后一个脚本
# Run gettys in standard runlevels
1:2345:respawn:/sbin/mingetty tty1
启动终端
/etc/inittab的任务
1.设定默认运行级别
2.运行系统初始化脚本
3.运行指定运行级别对应的目录下的脚本
4.设定Ctrl+Alt+Del组合键的操作
5.定义UPS电源在电源故障、恢复时执行的操作
6.启动虚拟终端(2345)
7.启动图形终端(5)
守护进程的类型
独立守护进程xinetd默认可能未安装,需自行安装 yum install xinetd
xinetd 超级守护进程代理人 需要关联至运行级别
瞬时守护进程:不需要关联至运行级别
本文转自Winthcloud博客51CTO博客,原文链接http://blog.51cto.com/winthcloud/1877226如需转载请自行联系原作者
Winthcloud