Linux中引导过程与服务控制

本文详细介绍了Linux操作系统引导过程,包括开机自检、MBR引导、GRUB菜单、加载内核和init进程初始化。此外,还讲解了如何排除启动故障,如修复MBR扇区和GRUB引导故障,以及遗忘root用户密码的处理。同时,文章阐述了系统服务的控制、运行级别的切换和优化启动过程的方法,涵盖了ntsysv工具和systemctl工具的使用。
摘要由CSDN通过智能技术生成

引导过程与服务控制

一、Linux操作系统引导过程

引导过程总览

image-20210910094754657

1.开机自检

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

总结:检测出第一个能够引导系统的设备(比如硬盘或光驱)BIOS设置了第一启动项

2.MBR引导

当从本机硬盘中启动系统时,首先根据硬盘第一个扇区中 MBR(Master Boot Record,主引导记录〉的设置,将系统控制权传递给包含操作系统引导文件的分区;

或者直接根据MBR记录中的引导信息调用启动菜单(如GRUB) 。

总结:运行放在MBR扇区里的启动GRUB引导程序

3.GRUB菜单

对于Linux操作系统来说,GRUB(GRand Unified Bootloader,统一启动加载器)是使用最为广泛的多系统引导器程序。系统控制权传递给GRUB以后,将会显示启动菜单给用户选择,并根据所选项(或采用默认值〉加载Linuz内核文件,然后将系统控制权转交给内核。需要注意的是,centos 7采用的是GRUB2启动引导器。

总结:GRUB引导程序通过读取GRUB配置文件/boot/grub2/grub.cfg,来获取内核和镜像文件系统的设置和路径位置

4.加载Linux内核

Linux内核是一个预先编译好的特殊二进制文件,介于各种硬件资源与系统程序之间,
负责资源分配与调度。内核接过系统控制权以后,将完全掌控整个Linux操作系统的运行过程。在centos系统中,默认的内核文件位于"/boot /vmlinuz-3.10.0-514.el7.x86_64"。

总结:把内核和镜像文件系统加载到内存中

5.init进程初始化

防火墙保护不受外部入侵,防水墙防御内部的泄密(1、U盘不能插,识别不了,有记录2、上网记录,屏蔽某些网站3、文件加密

为了完成进一步的系统引导过程,Linux内核首先将系统中的" /sbin/init”程序加载到内存中运行(运行中的程序称为进程),init_进程负责完成一系列的系统初始化过程,最后等待用户进行登录

总结:加载硬件驱动程序,内核把init进程加载到内存中运行

系统初始化进程

init进程

  • 由Linux内核加载运行/sbin/init程序
  • init进程是系统中第一个进程
  • init进程的PID(进程标记)号永远为1

Systemd

  • Systemd是Linux操作系统的一种init软件
  • CentOS7中采用全新的Systemd启动方式,取代传统的SysVinit
  • CentOS7中运行的第一个init进程是/lib/systemd/systemd

Systemd单元类型

单元类型扩展名说明
Service.service描述一个系统服务
Socket.socket描述一个进程间通信的套接字
Device.device描述一个内核识别的设备文件
Mount.mount描述一个文件系统的挂载点
Automount.automount描述一个文件系统的自动挂载点
Swapswap描述一个内存交换设备或交换文件
Path.path描述一个文件系统中文件或目录
Timer.timer描述一个定时器(用于实现类似cron的调度任务)
Snapshot.snapshot用于保存一个systemd的状态
Scope.scope使用systemd的总线接口以编程的方式创建外部进程
Slice.slice描述居于Cgroup的一组通过层次组织的管理系统进程
Target.target描述一组systemd的单元

运行级别所对应的 Systemd目标

运行级别systemd的target说明
0target关机状态,使用该级别时将会关闭主机
1rescue.target单用户模式,不需要密码验证即可登录系统,多用于系统维护
2multi-user.target用户定义/域特定运行级别。默认等同于3
3multi-user.target字符界面的完整多用户模式,大多数服务器主机运行在此级别
4multi-user.target用户定义/域特定运行级别。默认等同于3
5graphical.target图形界面的多用户模式,提供了图形桌面操作环境
6reboot.target重新启动,使用该级别时将会重启主机

二、排除启动类故障

修复MBR扇区故障

故障原因

  • 病毒、木马等造成的破坏
  • 不正确的分区操作、磁盘读写误操作

故障现象

  • 找不到引导程序,启动中断
  • 无法加载操作系统,开机后黑屏

解决思路

  • 应提前作好备份文件
  • 以安装光盘引导进入急救模式
  • 从备份文件中恢复

过程

将selinux关闭安全保密

[rootalocalhost ~]# setenforce 0

setenforce: SELinux is disabled

grub2-setpassword

设置grub密码

排除启动类故障

MBR位于第一块硬盘( /dev/sda)的第一一个物理扇区处,总共512字节

1.备份MBR扇区数据到其它磁盘(/dev /sdb1)

新建一个磁盘,将其分区后格式化

mkdir /data创建目录

mount /dev/sdb1 /data挂载到目录下

image-20210917081339537

image-20210917081533506

dd if=/dev/sda of=/backup/mbr.bak bs=512 count=1

dd=复制

if=你要复制的文件

of=你要复制后放在哪里

bs=复制的大小

count=复制的次数

image-20210917081617974

2.模拟破坏MBR引导扇区

打出以下代码看一眼/dev/sda里的内容

image-20210917213922616

输入dd if=/dev/zero of=/dev/sda bs=512 count=l

image-20210917214141938

3.引导界面进入急救模式,从备份文件中恢复MBR扇区数据

先加载好光盘镜像,重启操作系统,

image-20210917220123185

当出现安装问导界面时,选择"Troubleshooting"选项,

image-20210917220142304

再选择"Rescue a centos system"选项,进入急救模式

image-20210917220219220

选择“1"选择continue并按Enter键继续

再次按Enter键后将进入带"sh-4.2#"提示符的Bash Shell环境

image-20210917220448997

sh-4.2# mkdir /data

sh-4-2#mount /dev/sdb1 /data

#挂载带有备份文件的分区

sh-4.2#dd if=/data/mbr.bak of=/dev/sda

#恢复备份数据.

image-20210917221041301

sh-4.2# exit

#执行exit命令退出临时shell环境,系统将会自动重启

image-20210917221157029

image-20210917221257435

修复GRUB引导故障

故障原因
  • MBR中的GRUB引导程序遭到破坏
  • grub.conf文件丢失、引导配置有误
故障现象
  • 系统引导停滞,显示“grub>”提示符
解决思路
  • 尝试手动输入引导命令(过程繁琐,不建议使用)
  • 进入急救模式,重写或者从备份中恢复grub.conf(与修复MBR一致)
  • 向MBR扇区中重建grub程序

过程

模拟grub.conf文件丢失,将机器重启

image-20210918080114750

进入这个页面,将客户机重启,并在读条时按下Esc键

image-20210918080226915

image-20210918080629842

进入这个页面

image-20210918080604019

选择CD-ROM,回车

image-20210918080904819

选第三个选项

image-20210918080948015

选择第二个

image-20210918081119275

等待之后进入此页面,输入1

image-20210918081338071

输入

chroot /mnt/sysimage

grub2-install /dev/sda

image-20210918081813231

输入以下代码后,退出当前页面

image-20210918082411692

image-20210920204908186

重启之后,完成修复

image-20210920205134922

遗忘root用户密码

故障原因
  • 遗忘root用户的密码
故障现象
  • 无法进行需要root权限的管理操作
  • 若没有其他可用帐号,将无法登录系统
解决思路
  • 进入急救模式,重设密码
  • 进入单用户模式
过程

还是先进入急救模式

输入

chroot /mnt/sysimage

passwd root

image-20210920210245599

退出并重启

image-20210920210313877

服务控制及切换运行级别

系统服务控制

系统服务控制

systemctl 控制类型 服务名称

控制类型
  • start:启动
  • stop:停止
  • restart:重新启动
  • reload:重新加载
  • status:查看服务状态

Linux系统的运行级别

查看运行级别
runlevel命令

image-20210920215539337

N表示之前没有切换过运行级别,5表示当前运行级别

runlevel只能查看切换运行级别与当前运行级别

systemctl工具

systemctl时能查看默认的运行级别

image-20210920220753276

临时切换运行级别

init命令

systemctl工具

设置永久运行级别

优化启动过程

ntsysv工具
  • 提供一个交互式、可视化窗口
  • 可以在字符终端运行
  • 便于集中管理多个服务
systemctl工具
  • 不提供交互式、可视化窗口
  • 管理单个服务效率更高

系统服务的启动和控制

查看系统服务的启动状态

systemctl is-enabled服务名称

设置系统服务的启动状态

systemctl enableldisable服务名称

总结

systemctl时能查看默认的运行级别

[外链图片转存中…(img-kXY3ECQT-1632147278457)]

临时切换运行级别

init命令

systemctl工具

设置永久运行级别

优化启动过程

ntsysv工具
  • 提供一个交互式、可视化窗口
  • 可以在字符终端运行
  • 便于集中管理多个服务
systemctl工具
  • 不提供交互式、可视化窗口
  • 管理单个服务效率更高

系统服务的启动和控制

查看系统服务的启动状态

systemctl is-enabled服务名称

设置系统服务的启动状态

systemctl enableldisable服务名称

总结

掌握Linux操作系统引导过程,Linux系统服务控制(改密码),运行级别切换(0 3 5 6),优化开机自动加载服务

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值