引导过程:
1.开机自检
服务器主机开机以后,将根据主板 BIOS 中的设置对 CPU(Central Processing Unit, 中央处理器)、内 存、显卡、键盘等设备进行初步检测,检测成功后根据 预设的启动顺序移 交系统控制权,大多时候会移交给本 机硬盘。 网络启动 加载 网络批量pxe
- MBR引导
当从本机硬盘中启动系统时,首先根据硬盘第一个扇区 中 MBR(Master Boot Record, 主引导记录)的设 置,将系统控制权传递给包含操作系统引导文件的分 区;或者直接根据 MBR 记录中的引导信息调用启动菜单 (如 GRUB)。 总结:运行放在MBR扇区里的启动 GRUB引导程序
3.GRUB菜单 系统类型双西雅图 内核文件 默认值
对于 Linux 操作系统来说,GRUB(GRand Unified Bootloader,统一启动加载器)是 使用最为广泛的多系 统引导器程序。系统控制权传递给 GRUB 以后,将会显 示启动菜单给 用户选择,并根据所选项(或采用默认 值)准备加载 Linux 内核文件,然后将系统控制权转交 给 内核。需要注意的是,CentOS 7 采用的是 GRUB2 启 动引导器。 总结:GRUB引导程序通过读取GRUB配置文 件/boot/grub2/grub.cfg,来获取内核和镜像文件系统 的设置和路径位置
- 加载Linux内核 操作系统 调度硬件
Linux 内核是一个预先编译好的特殊二进制文件,介于 各种硬件资源与系统程序之间, 负责资源分配与调度。 内核接过系统控制权以后,将完全掌控整个 Linux 操作 系统的运行过 程。在 CentOS 系统中,默认的内核文件 位于“/boot/vmlinuz-3.10.0-514.el7.x86_64”。 总结:把内核和镜像文件系统加载到内存中 可以使用
- init进程初始化 这是linux 系统运行的第一个程序
为了完成进一步的系统引导过程,Linux内核首先将系统 中的“/sbin/init”程序加载到内 存中运行(运行中的程序 称为进程),init 进程负责完成一系列的系统初始化过 程,最后等待用户进行登录 总结:加载硬件驱动程序,内核把init进程加载到内存中 运行 传统init依赖于串行执行Shell 脚本启动服务,导致效率 低下,系统启动速度较慢 排队 systemd能够将更多的服务进程并行启动,并且具有提 供按需启动服务的能力,使得启动更少进程,从而提高 系统启动速度 大家一起
systemd服务
1.对比5 6 可以解决依赖关系并行启动
2.按需启动
3.自动解决依赖关系
负责在系统启动或运行时,激活系统资源,服务器进程 和其它进程
Systemd新特性
系统引导时实现服务并行启动
按需启动守护进程
自动化的服务依赖关系管理
同时采用socket式与D-Bus总线式激活服务
socket与服务程序分离
向后兼容sysv init脚本
使用systemctl 命令管理,systemctl命令固定不变, 不可扩展,非由systemd启动的服务,
systemctl无法与之通信和控制
系统状态快照
systemd 核心概念:unit
unit表示不同类型的systemd对象,通过配置文件进行 标识和配置;文件中主要包含了系统服务、监听 socket、保存的系统快照以及其它与init相关的信息
Grub 是一个程序,运行操作系统
centos7
淘汰了 init 通过脚本启动 1个1个起排队启动
使用新的systemed 并行启动进程
单元模块的方式去管理我们的进程提供服务
Service 最重要
运行级别:
0 关机
6 重启
1 单用户 系统维护 (比如改密码,破解密码)
234=3
5 图形界面
可以使用 Init 加上数字 切换级别
修复mbr分区
1.备份mbr引导扇区到其他磁盘
2.模拟破坏mbr引导扇区
3.引导镜像急救模式进行mbr扇区恢复
ip a a 192.168.100.100 dev ens33 配置IP地址
scp 192.168.100.100:/mbr.bak .
dd if=./mbr.bak of=/dev/sda bs=512 count=1
mkdir /bak
mount /dev/sdb1 /bak
dd if=/bak/mbr.bak of=/dev/sda #备份MBR分区表
dd if=/dev/sda of=/data/dpt.img bs=1 count=64 skip=446 scp /data/dpt.img 10.0.0.102: #破坏MBR分区表
[root@centos8 ~]#dd if=/dev/zero of=/dev/sda bs=1 count=64 seek=446 #无法启动
[root@centos8 ~]#reboot #用光盘启动,进入rescue mode,选第3项skip to shell
#配置网络 #ifconfig ens33 10.0.0.8/24
#ip a a 10.0.0.8/24 dev ens33
#scp 10.0.0.102:/root/dpt.img ./
#恢复MBR分区表
#dd if=dpt.img of=/dev/sda bs=1 seek=446
#reboot
新建一块硬盘 将mbr 备份 模拟破坏
急救模式
mkdir 、/bak
挂载硬盘
dd 还原
修复grub分区
rm -rf /boot/grub2/grub.cfg 配置文件
#模拟删除grub.cf 文件
进入急救模式,选择1 继续
chroot /mnt/sysimage
#进入急救模式后,更改环境
grub2-install /dev/sda
#重新建立加载sda分区
grub2-mkconfig -o /boot/grub2/grub.cfg
#重新构建grub菜单配置文件
修改密码
chroot /mnt/sysimage #进入急救模式后,更改环境
passwd #修改密码
设置运行级别
命令格式: systemctl [command] [unit.target] command参数:
get-default :取得当前的target
set-default :设置指定的target为默认的运行 级别 3 5
isolate :切换到指定的运行级别
unit.target :上面列出的运行级别
0:关机
1:单用户模式(root自动登录), single, 维护模式
2:多用户模式,启动网络功能,但不会启动NFS;维护 模式
3:多用户模式,正常模式;文本界面
4:预留级别;可同3级别
5:多用户模式,正常模式;图形界面 6:重启