linux 引导和服务

117 阅读5分钟

引导过程:

image.png

1.开机自检

服务器主机开机以后,将根据主板 BIOS 中的设置对 CPU(Central Processing Unit, 中央处理器)、内 存、显卡、键盘等设备进行初步检测,检测成功后根据 预设的启动顺序移 交系统控制权,大多时候会移交给本 机硬盘。 网络启动 加载 网络批量pxe

  1. 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,来获取内核和镜像文件系统 的设置和路径位置

  1. 加载Linux内核 操作系统 调度硬件

Linux 内核是一个预先编译好的特殊二进制文件,介于 各种硬件资源与系统程序之间, 负责资源分配与调度。 内核接过系统控制权以后,将完全掌控整个 Linux 操作 系统的运行过 程。在 CentOS 系统中,默认的内核文件 位于“/boot/vmlinuz-3.10.0-514.el7.x86_64”。 总结:把内核和镜像文件系统加载到内存中 可以使用

  1. init进程初始化 这是linux 系统运行的第一个程序

为了完成进一步的系统引导过程,Linux内核首先将系统 中的“/sbin/init”程序加载到内 存中运行(运行中的程序 称为进程),init 进程负责完成一系列的系统初始化过 程,最后等待用户进行登录 总结:加载硬件驱动程序,内核把init进程加载到内存中 运行 传统init依赖于串行执行Shell 脚本启动服务,导致效率 低下,系统启动速度较慢 排队 systemd能够将更多的服务进程并行启动,并且具有提 供按需启动服务的能力,使得启动更少进程,从而提高 系统启动速度 大家一起

image.png

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:重启

image.png

image.png

image.png

image.png

image.png

image.png

image.png