CentOS系统启动流程–上

centos6启动流程

1.加载BIOS的硬件信息,获取第一个启动设备。

2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息

3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱

动所有的硬件设备。

4.核型执行init程序并获取运行信息。

5.Init执行/etc/rc.d/rc.sysinit文件。

6.启动核心的外挂模块(/etc/modprobe.conf)。

7.Init执行运行的各个批处理文件(scripts).

8.Init执行/etc/rc.d/rc.local.

9.执行/bin/login程序,等待用户登录。

10.登录之后开始以Shell控制主机。

启动流程

POST:Power-On-Self-Test,加电自检,是BIOS功能的一个主要部分。负责完成对CPU、主板、内存、硬盘子系统、显示子系统、串并行接

口、键盘、CD-ROM光驱等硬件情况的检测。

ROM:BIOS,Basic Input and Output System,保存着有关计算机系统最重要的基本输入输出程序,系统信息设置、开机加电自检程序和

系统启动自举程序等。

RAM:CMOS互补金属氧化物半导体,保存各项参数的设定

按次序查找引导设备,第一个有引导程序的设备为本次启动设备

bootloader: 引导加载器,引导程序

windows: ntloader,仅是启动OS

Linux:功能丰富,提供菜单,允许用户选择要启动系统或不同的内核版本;把用户选定的内核装载到内存中的特定空间中,解压、展开,并把

统控制权移交给内核

LILO:LInux LOader

GRUB: GRand Unified Bootloader

GRUB 0.X: GRUB Legacy,GRUB2

MBR:

446: bootloader,  64: 分区表, 2: 55AA

GRUB:

primary boot loader : 1st stage,1.5 stage

secondary boot loader :2nd stage,分区文件

kernel:

自身初始化:

探测可识别到的所有硬件设备

加载硬件驱动程序(可能借助于ramdisk加载驱动)

以只读方式挂载根文件系统

运行用户空间的第一个应用程序:/sbin/init

——–

系统启动流程

v init程序的类型:

v SysV: init, CentOS 5之前

配置文件:/etc/inittab

v Upstart: init,CentOS 6

配置文件:/etc/inittab, /etc/init/*.conf

v Systemd:systemd, CentOS 7

配置文件:/usr/lib/systemd/system

/etc/systemd/system

——–

启动流程

ramdisk:

内核中的特性之一:使用缓冲和缓存来加速对磁盘上的文件

访问

ramdisk –> ramfs 提高速度

CentOS 5: initrd,  工具程序:mkinitrd

CentOS 6: initramfs, 工具程序:mkinitrd, dracut

系统初始化:

POST –> BootSequence (BIOS) –>

Bootloader(MBR) –> kernel(ramdisk) –> rootfs(只读) –> init (systemd

/sbin/init  CentOS 5

运行级别:为系统运行或维护等目的而设定;0-6:7个级别

0:关机

1:单用户模式(root 自动登录), single, 维护模式

2: 多用户模式,启动网络功能,但不会启动NFS;维护模式

3:多用户模式,正常模式;文本界面

4:预留级别;可同3级别

5:多用户模式,正常模式;图形界面

6:重启

默认级别:3, 5

切换级别:init #

查看级别:runlevel ; who -r

——

init初始化

vinit读取其初始化文件:/etc/inittab

初始运行级别(RUN LEVEL)

系统初始化脚本

对应运行级别的脚本目录

捕获某个关键字顺序

定义UPS电源终端/恢复脚本

在虚拟控制台生成getty

在运行级别5初始化X

CentOS5的inittab文件

配置文件:/etc/inittab

每一行定义一种action以及与之对应的process

id:runlevel:action:process

action:

wait: 切换至此级别运行一次;

respawn:此process终止,就重新启动之

initdefault:设定默认运行级别;process省略

sysinit:设定系统初始化方式,此处一般为指定

/etc/rc.d/rc.sysinit

ca::ctrlaltdel:/sbin/shutdown -t3 -r now

id:3:initdefault:

si::sysinit:/etc/rc.d/rc.sysinit

l0:0:wait:/etc/rc.d/rc 0

l1:1:wait:/etc/rc.d/rc 1…

l6:6:wait:/etc/rc.d/rc 6

CentOS6 /etc/inittab和相关文件

/etc/inittab

设置系统默认的运行级别

id:3:initdefault:

/etc/init/control-alt-delete.conf

/etc/init/tty.conf

/etc/init/start-ttys.conf

/etc/init/rc.conf

/etc/init/prefdm.conf

/etc/rc.d/rc.sysinit: 系统初始化脚本

(1) 设置主机名

(2) 设置欢迎信息

(3) 激活udev和selinux

(4) 挂载/etc/fstab文件中定义的文件系统

(5) 检测根文件系统,并以读写方式重新挂载根文件系统

(6) 设置系统时钟

(7) 激活swap设备

(8) 根据/etc/sysctl.conf文件设置内核参数

(9) 激活lvm及software raid设备

(10) 加载额外设备的驱动程序

(11) 清理操作

v 说明:rc N –> 意味着读取/etc/rc.d/rcN.d/

K*: K##*:##运行次序;数字越小,越先运行;数字

越小的服务,通常为依赖到别的服务

S*: S##*:##运行次序;数字越小,越先运行;数字

越小的服务,通常为被依赖到的服务

for srv in /etc/rc.d/rcN.d/K*; do

$srv stop

done

for srv in /etc/rc.d/rcN.d/S*; do

$srv start

done

chkconfig命令

chkconfig命令

查看服务在所有级别的启动或关闭设定情形:

chkconfig [–list] [name]

添加:

SysV的服务脚本放置于/etc/rc.d/init.d (/etc/init.d)

chkconfig –add name

#!/bin/bash

#LLLL 表示初始在哪个级别下启动,-表示都不启动

chkconfig: LLLL nn nn

删除:

chkconfig –del name

 修改指定的链接类型

chkconfig [–level levels] name

–level LLLL: 指定要设置的级别;省略时表示2345

 ntsysv命令

xinetd管理的服务

v service 命令:手动管理服务

service 服务 start|stop|restart

service –status-all

v 瞬态(Transient)服务被xinetd进程所管理

进入的请求首先被xinetd代理

配置文件:/etc/xinetd.conf、/etc/xinetd.d/

与libwrap.so文件链接

用chkconfig控制的服务:

chkconfig  tftp        on

v 注意:正常级别下,最后启动一个服务S99local没有链接至

/etc/rc.d/init.d一个服务脚本,而是指向了

/etc/rc.d/rc.local脚本

v 不便或不需写为服务脚本放置于/etc/rc.d/init.d/ 目录,且

又想开机时自动运行的命令,可直接放置于

/etc/rc.d/rc.local文件中

• /etc/rc.d/rc.local在指定运行级别脚本后运行

• 可以根据情况,进行自定义修改

识别硬盘设备:

(hd#,#)

hd#: 磁盘编号,用数字表示;从0开始编号

#: 分区编号,用数字表示; 从0开始编号

(hd0,0) 第一块硬盘,第一个分区

v 手动在grub命令行接口启动系统:

grub> root (hd#,#)

grub> kernel /vmlinuz-VERSION-RELEASE ro

root=/dev/DEVICE

grub> initrd /initramfs-VERSION-RELEASE.img

grub> boot

grub legacy配置文件

 配置文件:/boot/grub/grub.conf

default=#: 设定默认启动的菜单项;落单项(title)编号从0开始

timeout=#:指定菜单项等待选项选择的时长

splashimage=(hd#,#)/PATH/TO/XPM_FILE:菜单背景图片文件路径

hiddenmenu:隐藏菜单

password [–md5] STRING: 启动菜单编辑认证

title TITLE:定义菜单项“标题”, 可出现多次

root (hd#,#):grub查找stage2及kernel文件所在设备分区;为grub “根”

kernel /PATH/TO/VMLINUZ_FILE [PARAMETERS]:启动的内核

initrd /PATH/TO/INITRAMFS_FILE: 内核匹配的ramfs文件

password [–md5] STRING: 启动选定的内核或操作系统时进行认证

grub加密

vgrub-md5-crypt命令

破解root口令:

启动系统时,设置其运行级别1

v 进入单用户模式:

(1) 编辑grub菜单(选定要编辑的title,而后使用e命令);

(2) 在选定的kernel后附加

1, s, S或single都可以;

(3) 在kernel所在行,键入“b”命令

grub安装

安装grub:

(1) grub-install

安装grub stage1和stage1_5到/dev/DISK磁盘上,并

复制GRUB相关文件到 DIR/boot目录下

grub-install –root-directory=DIR /dev/DISK

破坏分区表时可以使用,这样重装可以使用

(2) grub 破坏分区表时不可以使用

grub> root (hd#,#)

grub> setup (hd#)

自制linux系统

 分区并创建文件系统

fdisk /dev/sdb

分两个必要的分区

/dev/sdb1对应/boot   /dev/sdb2对应根 /

mkfs.ext4 /dev/sdb1

挂载boot

mkdir /mnt/boot

mount /dev/sdb1 /mnt/boot

安装grub

grub-install –root-directory=/mnt /dev/sdb

自制linux系统

恢复内核和initramfs文件

cp /boot/vmlinuz-2.6.32-642.el6.x86_64

/mnt/boot/

cp /boot/initramfs-2.6.32-642.el6.x86_64.img

/mnt/boot

建立grub.conf文件

Vim /mnt/boot/grub.conf

kernel /vmlinuz-2.6.32-642.el6.x86_64

root=/dev/sda2  selinux=0 init=/bin/bash

chroot /mnt/sysroot

自制linux系统

创建一级目录

mkdir /mnt/sysroot

mount  /dev/sdb2   /mnt/sysroot

mkdir –pv

/mnt/sysroot/{etc,lib,lib64,bin,sbin,tmp,var,usr,sys,proc

,opt,home,root,boot,dev,mnt,media}

复制bash和相关库文件

救援环境

在根文件系统无法使用时需要,如/bin/mount删除

对系统没有特殊要求

从光盘引导(boot.iso或者安装光盘#1)

从USB盘(由boot.iso制作)引导

文件系统重组

Anaconda将会询问是否应该挂载文件系统

/mnt/sysimage/*

/mnt/stage2

$PATH包括硬盘的目录

文件系统节点

提供系统特定的设备文件

mknod了解major/minor #’sr

系统配置文件丢失修复

系统在引导期间,很重要的一个过程就是init进程读取其配

置文件/etc/inittab,启动系统基本服务程序及默认运行

级别的服务程序完成系统引导,如果/etc/inittab误删除

或修改错误,Linux将无法正常启动。此时,只有通过救援

模式才可以解决此类问题。

Ø     有备份文件的回复方法

Ø     没有备份文件的恢复办法

有备份文件的恢复办法:

进入救援模式,执行chroot命令后,如果有此文件

的备份(强烈建议系统中的重要数据目录,如/etc

、/boot等要进行备份),直接将备份文件拷贝回

去,退出重启即可。如果是配置文件修改错误,如

比较典型的/boot/grub/grub.conf及/etc/passwd

的文件修改错误,也可以直接修正恢复。假设有备

份文件/etc/inittab.bak,则在救援模式下执行:

sh-3.1# chroot /mnt/sysimage

sh-3.1# cp /etc/inittab.bak /etc/inittab

系统配置文件丢失修复

v 没有备份文件的恢复办法

如果一些配置文件丢失或软件误删除,且无备份,可以通过重新

安装软件包来恢复,首先查找到/etc/inittab属于哪一个RPM包

# chroot /mnt/sysimage

# rpm -qf /etc/inittab

initscripts-9.03.49-1.el6.centos.x86_64

退出chroot模式:

# exit

挂载存放RPM包的安装光盘(在救援模式下,光盘通常挂载在

/mnt/source目录下):

系统配置文件丢失修复

# mount /dev/sr0 /mnt/source

CentOS6系统的RPM包存放在光盘Package 目录下,另外,因

为要修复的硬盘系统的根目录在/mnt/sysimage下,需要使用-

-root选项指定其位置。覆盖安装/etc/inittab文件所在的RPM

包:

# rpm -ivh –replacepkgs | force /mnt/source/Packages/

initscripts-9.03.49-1.el6.centos.x86_64.rpm

其中的rpm命令选项“–replacepkgs”表示覆盖安装,执行完成

后,即已经恢复了此文件。

系统配置文件丢失修复

如果/etc/fstab文件被破坏后,如果分区时没卷标时就只能自己手动挂载根,挂载完成后重启让系统帮助挂载,继续救援模式,如果刚才挂载成功,则chroot模式会重新出现,重新安装grub.安装内核、、grub时无需指定boot目录

但是这里有个问题,如果etc/fstab文件没修复的话,则将/boot作为grub.conf的内核和虚拟文件系统的‘根’。

修复了etc/fstab文件则没有如上问题。在写grub.conf

如果想只提取RPM包中的/etc/inittab文件进行恢复,可以在进

入救援模式后,执行命令:

rpm2cpio Packages/initscripts-9.03.53-1.el6.centos.x86_64.rpm | cpio -itv

Rpm -qpl Packages/initscripts-9.03.53-1.el6.centos.x86_64.rpm

# rpm2cpio /mnt/source/Packages/initscripts-9.03.49-

1.el6.centos.x86_64.rpm| cpio -idv ./etc/binittab

# cp etc/inittab /mnt/sysimage/etc

注意此命令执行时不能将文件直接恢复至/etc 目录,只能提取到

当前目录下,且恢复的文件名称所在路径要写完整的路径。提取

文件成功后,将其复制到根分区所在的/mnt/sysimage 目录下相

应位置即可

etc/fstab 没了的话只能重新查找逻辑卷lvscan

vgchange -ay 可以激活逻辑卷



 

原创文章,作者:sjfbjs,如若转载,请注明出处:http://www.178linux.com/45254

(0)
上一篇 2016-09-13 15:19
下一篇 2016-09-13 15:19

相关推荐

  • 硬链接和软链接的区别

    硬链接和软链接的区别 1、概念 在linux中,链接可分为两种:一种为硬链接,另一种为软链接。硬链接:ln 源文件 目标文件软链接:ln -s(soft)源文件 目标文件 硬链接 硬链接是指通过索引节点inode来进行链接。linux系统中每个文件对应一个inode,并且允许多个文件名指向用一个inode。这种情况的文件就成为硬链接。它的作用之一就是允许一个…

    Linux干货 2017-07-23
  • 制作本地yum源与编译安装http

    1、制作本地yum源(centos7) [root@centos7 ~]# yum install -y lftp   #安装lftp程序 lftp 10.1.0.1:~> cd pub/Sources/sources/xen/ &n…

    Linux干货 2016-08-25
  • 关于压测的宏观个人总结

    工作角色定位 首先先从宏观角度来评估下本次的压测工作. 从工作职责上说本次压测理应由组内其它同学来完成,个人从旁协助或指导即可。团队成员的成长对我个人来说才是更大的成长。所以即使这次压测工作完成的再出色,都会因为是由我来完成的,所以都不能称之为优秀的。对我个人的成长最多是项目经验的增长和问题的积累,但对组员来说如何让他们做到现有成果的80%是我需要帮助他们来…

    Linux干货 2015-04-21
  • keepalived+varnish+haproxy+LNAMP

      nfs: 192.168.1.40 rp1: 192.168.1.41 rp2: 192.168.1.42 mariadb: 192.168.1.43 web1: 192.168.1.110 web2: 192.168.1.111 app1: 192.168.1.112 app2: 192.168.1.113 实验效果:用keepalived高…

    2018-02-18
  • N22-妙手-第二周博客作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示     mkdir: 创建目录         使用方法:mkdir [OPTION]… DIRECTORY…   &n…

    Linux干货 2016-08-29
  • Nginx常用配置详解

    Nginx常用配置详解(一) 本文依照nginx官方站点文档介绍常用的nginx各种常用配置,未经过校对,如有错误还望海涵。 Nginx配置通用语法 Nginx最基本的配置语法 配置项名 配置项值1 [配置项值2 ….]; 配置项名位于行首,配置项值与配置项名之间用空格隔开,多个配置项值之间也用空格隔开,每行配置结尾必须加上分号。 #配置项名 配置项值1…

    Linux干货 2017-06-20