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=#:指定菜單項等待選項選擇的時長
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-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/sysimage目錄下面
之前那一步驟,只是稍微的修復了系統配置文件里面的兩個分區的信息而已
下面,我們需要對內核和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/sysimage目錄里面的,跟此前的操作是一樣的
進入到救援模式,就開始修復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目錄下面看到它,好了,既然知道文件在那里,那么修改起來大家就知道怎么操作了吧?不過有一個要求就是此圖片的分辨率為640×480.而且替換的背景的圖片也需要跟原文件一樣的后綴名,就是需要生成XXX.xpm.gz這樣格式的圖片
然后把需要替換的原圖,用此工具編輯一下,然后把編輯完的圖片放到/boot/grub/目錄下面
這就是修改完開機背景的linux系統,是不是很炫酷?
修改圖片具體操作步驟
原創文章,作者:~微風~,如若轉載,請注明出處:http://www.www58058.com/47764
內容很完整,實驗部分操作也很流暢,贊一個。