boot loader裝入kernel, 然后kernel需要執(zhí)行/sbin/init, 讀取
這個(gè)文件就必須先mount根文件系統(tǒng), 早期是通過(guò)啟動(dòng)時(shí)的root=
參數(shù)告訴內(nèi)核根文件系統(tǒng)在哪個(gè)設(shè)備上, 隨著硬件和技術(shù)的發(fā)展,
現(xiàn)在根文件系統(tǒng)可能位于一個(gè)網(wǎng)絡(luò)存儲(chǔ)如NFS上, 可能由于RAID而
散布于多個(gè)設(shè)備上, 可能位于一個(gè)加密設(shè)備上需要提供用戶名和密碼,
這時(shí)root=參數(shù)就顯得不夠了. 為了應(yīng)付這種局面, 先后出現(xiàn)兩種
機(jī)制來(lái)作為boot loader裝載kernel到真正的/sbin/init執(zhí)行這個(gè)啟動(dòng)
過(guò)程的橋梁: initrd和initramfs, 兩者有類似的地方, 比如都是
由內(nèi)核執(zhí)行其上的某個(gè)程序(initrd是/linuxrc, initramfs是/init),
由這個(gè)程序決定加載什么驅(qū)動(dòng)以及如何裝載根文件系統(tǒng). 下面一點(diǎn)
筆記總結(jié)initrd的缺點(diǎn)和initramfs的優(yōu)點(diǎn).
initrd:
ram disk是一個(gè)基于ram的塊設(shè)備,因此它占據(jù)了一塊固定的內(nèi)存,
而且事先要使用特定的工具比如mke2fs格式化,還需要一個(gè)文件系統(tǒng)
驅(qū)動(dòng)來(lái)讀寫其上的文件。
如果這個(gè)disk上的空間沒(méi)有用完,這些未用的內(nèi)存就浪費(fèi)掉了,并且
這個(gè)disk的空間固定導(dǎo)致容量有限,要想裝入更多的文件就需要重新
格式化。
由于Linux的塊設(shè)備緩沖特性, ram disk上的數(shù)據(jù)被拷貝到page cache
(對(duì)于文件數(shù)據(jù))和dentry cache(對(duì)于目錄項(xiàng)), 這個(gè)也導(dǎo)致內(nèi)存浪費(fèi).
initramfs:
最初的想法是Linus提出的: 把cache當(dāng)作文件系統(tǒng)裝載. 他在一個(gè)叫
ramfs的cache實(shí)現(xiàn)上加了一層很薄的封裝, 其它內(nèi)核開(kāi)發(fā)人員編寫了
一個(gè)改進(jìn)版tmpfs, 這個(gè)文件系統(tǒng)上的數(shù)據(jù)可以寫出到交換分區(qū), 而且
可以設(shè)定一個(gè)tmpfs裝載點(diǎn)的最大尺寸以免耗盡內(nèi)存. initramfs就是
tmpfs的一個(gè)應(yīng)用.
優(yōu)點(diǎn):
(1)tmpfs隨著其中數(shù)據(jù)的增減自動(dòng)增減容量.
(2)在tmpfs和page cache/dentry cache之間沒(méi)有重復(fù)數(shù)據(jù).
(3)tmpfs重復(fù)利用了Linux caching的代碼, 因此幾乎沒(méi)有增加內(nèi)核
尺寸, 而caching的代碼已經(jīng)經(jīng)過(guò)良好測(cè)試, 所以tmpfs的代碼質(zhì)量
也有保證.
(4)不需要額外的文件系統(tǒng)驅(qū)動(dòng).
另外, initrd機(jī)制被設(shè)計(jì)為舊的"root="機(jī)制的前端, 而非其替代物,
它假設(shè)真正的根設(shè)備是一個(gè)塊設(shè)備, 而且也假設(shè)了自己不是真正的根設(shè)備,
這樣不便將NFS等作為根文件系統(tǒng), 最后/linuxrc不是以PID=1執(zhí)行的, 因?yàn)?br>1這個(gè)進(jìn)程ID是給/sbin/init保留的. initrd機(jī)制找到真正的根設(shè)備后將
其設(shè)備號(hào)寫入/proc/sys/kernel/real-root-dev, 然后控制
轉(zhuǎn)移到內(nèi)核由
其裝載根文件系統(tǒng)并啟動(dòng)/sbin/init.
initramfs則去掉了上述假設(shè), 而且/init以PID=1執(zhí)行, 由init裝載根文件
系統(tǒng)并用exec轉(zhuǎn)到真正的/sbin/init, 這樣也導(dǎo)致一個(gè)更為干凈漂亮的設(shè)計(jì).