日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

Linux系统启动过程及其修复过程简析(CentOS5、6)

發布時間:2023/12/18 linux 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux系统启动过程及其修复过程简析(CentOS5、6) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Linux組成

Linux: kernel+rootfs

????kernel: 進程管理、內存管理、網絡管理、驅動程序、文件系統、安全功能

????rootfs:程序和glibc

????庫:函數集合, function, 調用接口(頭文件負責描述)

????????過程調用:procedure,無返回值

????????函數調用:function

????程序:二進制執行文件

內核設計流派:

????單內核(monolithic kernel):Linux

????????把所有功能集成于同一個程序

????微內核(micro kernel):Windows, Solaris

????????每種功能使用一個單獨子系統實現


內核

Linux內核特點:

????支持模塊化:.ko(內核對象)

????????如:文件系統,硬件驅動,網絡協議等

????支持內核模塊的動態裝載和卸載

組成部分:

????核心文件:/boot/vmlinuz-VERSION-release

????????ramdisk:輔助的偽根系統

????????CentOS 5: /boot/initrd-VERSION-release.img

????????CentOS6,7: /boot/initramfs-VERSION-release.img

????模塊文件:/lib/modules/VERSION-release


示例:Linux的核心文件



CentOS 6的啟動流程

1.加載BIOS的硬件信息,獲取第一個啟動設備

2.讀取第一個啟動設備MBR的引導加載程序(grub)的啟動信息

3.加載核心操作系統的核心信息,核心開始解壓縮,并嘗試驅動所有的硬件設備

4.核心執行init程序,并獲取默認的運行信息

5.init程序執行/etc/rc.d/rc.sysinit文件

6.啟動核心的外掛模塊

7.init執行運行的各個批處理文件(scripts)

8.init執行/etc/rc.d/rc.local

9.執行/bin/login程序,等待用戶登錄

10.登錄之后開始以Shell控制主機 ? ?


Linux啟動流程

1、POST:Power-On-Self-Test,加電自檢,是BIOS功能的一個主要部分。負責完成對CPU、主板、內存RAM、硬盤子系統、顯示子系統、串并行接口、鍵盤、CD-ROM光驅等硬件情況的檢測。

????ROM:BIOS,Basic Input and Output System,保存著有關計算機系統最重要的基本輸入輸出程序,系統信息設置、開機加電自檢程序和系統啟動自舉程序等。

????RAM:CMOS互補金屬氧化物半導體,保存各項參數的設定按次序查找引導設備,第一個有引導程序的設備為本次啟動設備

2、MBR:

? ??其中Bootloader占據446字節,分區表占據64字節,magic num占據2字節。MBR將加載Bootloader去開始后邊的工作。

3、bootloader: 引導加載器,引導程序

????Linux:功能豐富,提供菜單,允許用戶選擇要啟動系統或不同的內核版本;把用戶選定的內核裝載到內存中的特定空間中,解壓、展開,并把系統控制權移交給內核

????LILO:Linux Loader

Bootloader(內核加載器)位于第0磁道第0扇區的446字節是最前邊的446字節!Bootloader的工作機制:bootloader可以訪問文件系統,而內核則作為文件而存在。所以bootloader可以訪問內核文件,深入的說bootloader訪問內核文件時,是將內核文件Vmlinz所在的整個分區當作根去訪問的,如訪問/Vmlinz而根"/"本身的存在位置是由內核文件自己決定。(因為每個文件必須要有一個自己的起始路徑)現代我們常用的內核加載器是grub(Grand Unified Bootloader)以此grub來加載內核。加載內核之前grub所做的工作

4、GRUB:就是MBR中的前 446 個字節,是BooTLoader的一種,它的作用是要選擇要啟動的內核

????primary boot loader : 1st stage,1.5 stage

????secondary boot loader :2nd stage,分區文件

/boot/grub文件夾里面有各種啟動的文件備份

主要是由device.map,menulst,stage1,stage2,以及一系列的stage1_5組成。

device.map:存放的是內核文件的根分區

grub.conf:就是菜單列表。里面設置了可以選擇的內核菜單,存放于stage2中。

stage:用于grub引導程序過大,所以分2段引導,第一段存放在MBR中,第二段存放于內核文件系統中,第一段引導完成后可以找到第二段。 但是,第二段是存放于內核文件系統中的,此時還沒有格式化文件系統,如何可以訪問到第二段的 menu.lst 呢??就需要借助于中間層 stage1_5,有它來協助 stage1 段來訪問 stage2 段。stage1_5通常位于 stage1 字段后的 63 個扇區。 由于stage2 在內存中存放可以使用的文件系統不確定,所以這就是有多個 stage1_5 的原因了。


示例:grub.conf文件


5、kernel:

? ?自身初始化:

????探測可識別到的所有硬件設備

????加載硬件驅動程序(可能借助于ramdisk加載驅動)

????以只讀方式掛載根文件系統

????運行用戶空間的第一個應用程序:/sbin/init



系統啟動流程

init程序的類型

SysV: init, CentOS 5之前

????配置文件:/etc/inittab

Upstart: init,CentOS6

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

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 6之前

運行級別:為系統運行或維護等目的而設定;0-6:7個級別

????0:關機

????1:單用戶模式(root自動登錄), single, 維護模式

????2: 多用戶模式,啟動網絡功能,但不會啟動NFS;維護模式

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

????4:預留級別;可同3級別

????5:多用戶模式,正常模式;圖形界面

????6:重啟

默認級別:3(多用戶CLI模式), 5(圖形化模式)

切換級別:init#

查看級別:runlevel; who -r


init讀取其初始化文件:/etc/inittab

????初始運行級別(RUN LEVEL)

????系統初始化腳本

????對應運行級別的腳本目錄

????捕獲某個關鍵字順序

????定義UPS電源終端/恢復腳本

????在虛擬控制臺生成getty

????在運行級別5初始化X


CentOS 5的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/rc0

????l1:1:wait:/etc/rc.d/rc1...

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


CentOS 6 /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


示例:CentOS6的/etc/inittab文件。如果需要設置為圖形化啟動,把3改成5即可

/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) 清理操作


說明:rcN --> 意味著開機讀取/etc/rc.d/rcN.d/

????K*: K##*:##運行次序;數字越小,越先運行;數字越小的服務,通常為依賴到別的服務

????S*: S##*:##運行次序;數字越小,越先運行;數字越小的服務,通常為被依賴到的服務

啟動服務的腳本:

????for srvin /etc/rc.d/rcN.d/K*; do

????????$srv stop

????done

????for srvin /etc/rc.d/rcN.d/S*; do

????????$srv start

????done


示例:屬于init3開機級別的服務進程文件


chkconfig命令 --?查看服務在所有級別的啟動或關閉設定情形:

????chkconfig [--list] [name]

添加:

????SysV的服務腳本放置于/etc/rc.d/init.d(/etc/init.d)

????chkconfig --add name

????????#!/bin/bash

????????#LLLL 表示初始在哪個級別下啟動,-表示都不啟動

????????# chkconfig: LLLL nnnn

刪除:

????chkconfig --del name

修改指定的鏈接類型

????chkconfig [--level levels] name <on|off|reset>

???????? ?--level LLLL: 指定要設置的級別;省略時表示2345

ntsysv命令:圖形化的chkconfig命令


示例:制作一個模擬服務進程,并啟動它

#chkconfig:2345表示能被這幾個級別的init程序運行,88表示啟動優先級,22表示關閉優先級

把腳本復制到/etc/init.d/目錄下面

添加腳本到服務里面,可以看見腳本默認的啟動級別了,這個是根據腳本里面來定義的

可以關閉某些運行的級別

可以查看到/etc/rc.d/rcN.d/文件夾下面的各種K和S打頭的testservice文件

可以用chkconfig --level N SERVICE on | off 修改服務的開機默認開啟狀態

可以看見,其實/etc/rc.d/rcN.d/下面的K和S打頭的文件就是一個軟鏈接而已~

至于為什么這些只是一個軟鏈接的文件,大家可以參考/etc/rc.d/rc的腳本里面可以看到

例如這里定義K開頭的服務,這里只是rc腳本的一部分。

測試此服務開啟,關閉


守護進程:xinetd管理的服務(很多的服務依賴于此服務)

service 命令:手動管理服務

????service 服務start|stop|restart

????service --status-all

瞬態(Transient)服務被xinetd進程所管理

進入的請求首先被xinetd代理

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

與libwrap.so文件鏈接

用chkconfig控制的服務:

????chkconfigtftpon

注意:正常級別下,最后啟動一個服務S99local沒有鏈接至/etc/rc.d/init.d一個服務腳本,而是指向了/etc/rc.d/rc.local腳本

不便或不需寫為服務腳本放置于/etc/rc.d/init.d/目錄,且又想開機時自動運行的命令,可直接放置于/etc/rc.d/rc.local文件中

/etc/rc.d/rc.local在指定運行級別腳本后運行

可以根據情況,進行自定義修改


總結:/sbin/init--> (/etc/inittab) --> 設置默認運行級別--> 運行系統初始腳本、完成系統初始化--> (關閉對應下需要關閉的服務)啟動需要啟動服務--> 設置登錄終端


CentOS 6 init程序為: upstart, 其配置文件:

/etc/inittab, /etc/init/*.conf,配置文件的語法遵循upstart配置文件語法格式,和CentOS5不同


示例:破解CentOS5和6的root口令

首先,在進入菜單這里,點擊a進入編輯內核參數

在參數后面加一個1 | s | S | singel 參數都可以,然后輸入回車,進入單機模式

在單機模式下面,直接輸入passwd命令修改root賬號密碼,搞定。


grub legacy

CentOS 6啟動流程

????POST --> Boot Sequence(BIOS) --> Boot Loader --> Kernel(ramdisk) --> rootfs--> switchroot--> /sbin/init-->(/etc/inittab, /etc/init/*.conf) --> 設定默認運行級別--> 系統初始化腳本rc.sysinit--> 關閉或啟動對應級別的服務--> 啟動終端

grub: GRand Unified Bootloader

? ?grub 0.97: grub legacy

? ?grub 2.x: grub2

? ?grub legacy:

?????stage1: mbr

?????stage1_5: mbr之后的扇區,讓stage1中的bootloader能識別stage2所在的分區上的文件系統

?????stage2:磁盤分區(/boot/grub/)

配置文件:/boot/grub/grub.conf <--/etc/grub.conf(軟鏈接)

stage2及內核等通常放置于一個基本磁盤分區


功用

(1) 提供啟動菜單、并提供交互式接口

????a:內核參數

????e: 編輯模式,用于編輯菜單

????c: 命令模式,交互式接口

(2) 加載用戶選擇的內核或操作系統

????允許傳遞參數給內核

????可隱藏啟動菜單

(3) 為菜單提供了保護機制

????為編輯啟動菜單進行認證

????為啟用內核或操作系統進行認證


grub的命令行接口

????help: 獲取幫助列表

????help KEYWORD: 詳細幫助信息

????find (hd#,#)/PATH/TO/SOMEFILE:

????root (hd#,#)

????kernel /PATH/TO/KERNEL_FILE: 設定本次啟動時用到的內核文件;額外還可添加許多內核支持使用的cmdline參數

????例如:max_loop=100 selinux=0init=/path/to/init

????initrd/PATH/TO/INITRAMFS_FILE: 設定為選定的內核提供額外文件的ramdisk

????boot: 引導啟動選定的內核

cat /proc/cmdline 查看內核的位置

內核參數文檔:/usr/share/doc/kernel-doc-2.6.32/Documentation/kernel-parameters.txt



識別硬盤設備:

????(hd#,#)

????hd#: 磁盤編號,用數字表示;從0開始編號

????#: 分區編號,用數字表示; 從0開始編號

????(hd0,0) 第一塊硬盤,第一個分區


手動在grub命令行接口啟動系統:

????grub> root (hd#,#)

????grub> kernel /vmlinuz-VERSION-RELEASE roroot=/dev/DEVICE

????grub> initrd/initramfs-VERSION-RELEASE.img

????grub> boot




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

default=#: 設定默認啟動的菜單項;落單項(title)編號從0開始

timeout=#:指定菜單項等待選項選擇的時長

splashp_w_picpath=(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-md5-crypt命令

破解root口令:

????啟動系統時,設置其運行級別1

進入單用戶模式:

????(1) 編輯grub菜單(選定要編輯的title,而后使用e命令);

????(2) 在選定的kernel后附加1, s, S或single都可以;

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


openssl?命令

openssl passwd -1 密碼加密

openssl passwd -salt "HRSby" -1 指定鹽為"HRSby"


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#)


示例1:新建一個啟動項,并且調整內核參數

修改grub.conf文件的參數

default=1 即是開機的時候默認啟動第二個選項,默認是0

password --md5 XXX 那里的意思,如果在title前面,那么進入菜單欄前面的時候會提示輸入密碼,

如果在title后面。那么在進入指定的菜單的時候,會提示輸入密碼。

kernel 內核后面加了max_loop=20 selinux=0 rhgb quiet,一會看一下效果

然后在此處,默認選中了剛創建的Hello Linux的啟動菜單

在進入菜單后,會發現,提示我們輸入密碼

kernel rhgb quiet 的效果,靜默進入操作系統,這個功能不建議選用,因為看不到開機的啟動菜單

如果沒有內核參數rhgb quiet的話,我們可以看見每個進程的開機自檢過程

kernel max_loop=20的效果,默認的話只有7個


示例2:當引導有問題的時候,手動輸入命令啟動系統



假如grub里面設置了系統啟動密碼

啟動的時候發現忘記了密碼,囧,怎么辦

此時可以退回菜單,選擇c的的cli啟動方式。

手動輸入root的位置,內核,以及initramfss的位置,然后輸入boot加載

因為selinux的關系,啟動的時候可能系統會進行自檢,此時等待一會就可以了,又后者可以在內核參數那里直接添加selinux=0來跳過系統自檢

然后發現已經可以登陸進去系統了,此時再登陸進去,然后把grub.conf里面的password刪掉就可以了


示例3:分區情況下,刪除/boot 和/etc/fstab,破壞446字節的mbr信息,并恢復之

首先,破壞mbr前446個字節,把/boot目錄下面所有的文件刪除,把/etc/grub.conf文件刪除


此時再重啟,會發現,計算機根本就識別不到硬盤上面的系統

此時我們放入光盤(此步驟也可以從其他有同樣文件的地方來scp拷一份過來)


加載光盤里面的救援模式


然后進去救援模式,會提示我們的計算機上面沒有發現linux分區,因為我們前面把分區表破壞了

此處選擇開啟shell就可以

進入到救援模式的cli界面,此時需要操作的是:

  • 假設我們并不了解此計算機的分區,首先要查詢原來的分區表,此時可以用用lsblk命令查看到此前系統的塊設備信息,雖然可以看到塊設備信息,但是我們還是不能夠了解此前的分區信息,df命令出來的結果也并沒有顯示,所以,此時我們只能夠推斷此前的/根目錄是在哪個位置。

  • 創建一個空的目錄,然后把塊設備掛載到此目錄

  • 通過掛載,然后ls查看里面的信息,然后可以推斷出來此前的根目錄大概是哪里,還有boot分區在哪里,找到根目錄和boot目錄,然后就可以進入下一步的操作了

  • 創建/etc/fstab文件,以保存我們已知的分區信息

  • 此處由于暫時只知道兩個信息,然后把信息寫入到此文件

    完成此掛載信息后,千萬不能自己再對根目錄等進行操作,以免造成其他問題,此處應該要重啟電腦

    重啟電腦以后再進入救援模式,會發現,已經提示有找到linux系統了,并且把系統掛載到了/mnt/sysp_w_picpath目錄下面

    之前那一步驟,只是稍微的修復了系統配置文件里面的兩個分區的信息而已

    下面,我們需要對內核和grub進行修復

    1.首先,掛載光驅到一個空目錄,然后安裝光盤里面的內核~

    2.安裝完內核以后,我們可以切換到真實的系統,可以發現/boot目錄下面的文件大部分已經修復了,但是此處還是沒有grub.conf文件

    3.然后我們開始對grub文件進行修復,命令是grub-install DEVICE

    修復的過程中,會彈出來好多信息,注意的是千萬不要中斷此操作,不然會出現問題

    等了一段時間以后,會發現修復已經完成,但是grub文件還是沒有,因為此處只是修復mbr

    然后我們自己創建一個grub.conf的文件,并且手動添加以下等核心信息

    編輯完,重啟計算機

    然后此處會遇上selinux自檢,需要等待一段時間了,如果想調過此步操作,可以在之前的操作里面添加到kernel那一行的最后那里輸入selinux=0,以此來關閉selinux,不過不是很建議這么操作。

    好久以后,發現登陸界面已經出來了~此時修復操作已經完畢。

    注意:此操作是恢復了,但是分區表里面的信息,還是剛剛手動添加的分區表的信息,所以重啟掛載那些分區也是一個麻煩的事情,通過此案例,大家可以知道mbr引導,/boot目錄和/etc/fstab的重要性了吧?所以這些文件,最好平時就最好備份的操作,以免等到出現問題才來修復,會浪費很多的時間的。


    示例4:假設是在邏輯卷情況下,刪除mbr 、/boot 和/etc/fstab,并且恢復之

    之前的示例3是在普通的磁盤上面的修復操作,但是生產環境中,很可能我們會用上邏輯卷等,那么修復的操作就一樣了,但是修復的原理是跟示例3的幾乎是一樣的,只是在修復邏輯卷的地方稍有不同。

    此處的前面的步驟是跟示例3的是一樣的,所以此處只界面跟示例3不一樣的地方


    首先,也是需要進入救援模式

    當mbr 、/boot 和/etc/fstab等信息刪除以后,進入救援模式里面也是提示找不到linux分區,此處我們依然不需要理會

    進入到救援模式里面,我們直接用blkid命令,發現邏輯卷也沒有顯示出來,所以此處應該用邏輯卷的命令

    1、輸入lvscan,然后就可以查找到此前系統里面的邏輯卷,并且此處帶有邏輯卷板的卷標,一看就知道該邏輯卷是掛載到哪里的,這樣的話對于我們修復的幫助就非常大

    2、輸入vgchange -ay激活邏輯卷分區,默認的話是不激活的,所以開始的時候用blkid是不會顯示,在激活以后再輸入blkid,會發現已經可以查看到相關的信息。

    3、找到分區信息的,下一步就跟示例3的一樣,需要掛載分區信息了

    編輯/etc/fstab文件,輸入相關的掛載信息

    編輯完文檔,此刻就可以重啟了

    重啟完再重新進入救援模式,會提示系統已經掛載到/mnt/sysp_w_picpath目錄里面的,跟此前的操作是一樣的

    進入到救援模式,就開始修復grub的mbr信息,此操作過程跟示例3的一樣就不重復展示了。

    修復完mbr的信息,此時就可以手動創建grub.conf文件

    此處的kernel后面root=/dev/vg0/root,而不是此前的/dev/sda2,需要注意了,應該現在的root根目錄是掛載在邏輯卷里面,此處就是指定根的目錄位置,編輯完grub.conf文件,確認沒有問題就重啟電腦

    重啟完電腦以后,可以發現已經可以重新進入系統了,此處實驗已經完畢。


    示例5:修改Linux開機背景

    有時候,Linux黑色的開機北京略顯無聊,此處我們當然也可以修改拉

    在grub.conf文件里面我們可以此處有一個指向(hd0,0)/grub/splash.xpm.gz文件,這個就是開機的背景文件了,并且是個壓縮的文件。

    此文件我們可以在/boot/grub目錄下面看到它,好了,既然知道文件在那里,那么修改起來大家就知道怎么操作了吧?不過有一個要求就是此圖片的分辨率為640x480.而且替換的背景的圖片也需要跟原文件一樣的后綴名,就是需要生成XXX.xpm.gz這樣格式的圖片

    此處我們需要一個linux的工具ImageMagick軟件

    然后把需要替換的原圖,用此工具編輯一下,然后把編輯完的圖片放到/boot/grub/目錄下面

    這就是修改完開機背景的linux系統,是不是很炫酷?

    修改圖片具體操作步驟


    轉載于:https://blog.51cto.com/weiweidefeng/1854066

    總結

    以上是生活随笔為你收集整理的Linux系统启动过程及其修复过程简析(CentOS5、6)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。