敘述Ubuntu upstart進(jìn)程管理
在向大家詳細(xì)介紹Ubuntu upstart之前,首先讓大家了解下ubuntu,然后全面介紹Ubuntu upstart,希望對(duì)大家有用。Ubuntu系統(tǒng)的特性,并結(jié)合應(yīng)用實(shí)例進(jìn)行講解,引導(dǎo)讀者較快地掌握Ubuntu系統(tǒng)。ubuntu從6.10開始逐步用Ubuntu upstart代替原來的sysinit,進(jìn)行服務(wù)進(jìn)程的管理。也正是從6.10開始,ubuntu的啟動(dòng)過程開始變得有點(diǎn)“變幻莫測(cè)”。也沒辦法,這是正在開發(fā)中的Ubuntu upstart不可避免的。
為了對(duì)原有的init實(shí)現(xiàn)向后兼容,Ubuntu upstart可以說是在表象上保留了大部分原來init的特性,因而目前l(fā)inux初始化進(jìn)程名仍然叫init,而改變的核心,乃是Event機(jī)制。理解并講清楚這個(gè)改變的重要意義和內(nèi)在機(jī)理可不是件容易的事,所以我只打算研究一下目前 Ubuntu upstart(0.3.9, ubuntu 8.04)在系統(tǒng)啟動(dòng)中的表象行為。[注:據(jù)Scott James Remnant在其博客上所說,Ubuntu upstart 0.5.0版本將在未來幾周發(fā)布。
關(guān)于系統(tǒng)啟動(dòng),熟悉Linux的人大多應(yīng)該知道,init進(jìn)程(PID=1)乃是所有進(jìn)程的父進(jìn)程,所有進(jìn)程由它控制。init進(jìn)程的運(yùn)行時(shí)間是內(nèi)核完成文件系統(tǒng)的加載后。那么init進(jìn)程是如何開啟系統(tǒng)中的其它進(jìn)程的呢?在闡述這個(gè)問題之前,大致地說明一下目前ubuntu中與init相關(guān)的幾個(gè)目錄和應(yīng)用程序,可以方便后面的論述。這些目錄和程序包括:
init
telinit
runlevel
/etc/event.d/ /etc/init.d/ /etc/rcX.d/
前三個(gè)是應(yīng)用程序(注意哦,它們都不是shell腳本),可以理解為是由內(nèi)核調(diào)用的。關(guān)于它們的功能,從manpage查看就可以了。我們的重點(diǎn)是后面給出的三個(gè)目錄。
首先是/etc/event.d/目錄,這是Ubuntu upstart的核心,Ubuntu upstart不同于原有的init的地方就在于它引入了event機(jī)制。Event 機(jī)制通俗的講就是將所有進(jìn)程的觸發(fā)、停止等等都看作event(事件)。/etc/event.d/中就存放了目前Ubuntu upstart需要識(shí)別的event。這其中主要有三種rc-default, rcX(x=0,1,...6,S。sysv-rc-conf這個(gè)工具里就顯示了0,1,...6,S這幾個(gè)級(jí)別)以及ttyX。這rc-default 就類似于那大名鼎鼎的inittab文件,它就是設(shè)置默認(rèn)運(yùn)行級(jí)別的 [注:Ubuntu upstart中實(shí)際并沒有運(yùn)行級(jí)別的概念,這么稱呼是為了init向后的兼容性]?,F(xiàn)在你應(yīng)該知道了ubuntu里沒有了inittab文件后該到哪里設(shè)置默認(rèn)運(yùn)行級(jí)別的了吧!cat rc-default一下吧!rcX文件是發(fā)生相應(yīng)運(yùn)行級(jí)別事件(可以注意到event這個(gè)詞在Ubuntu upstart里真是無處不見啊)時(shí),需要運(yùn)行程序的腳本,而ttyX則是設(shè)置偽終端數(shù)目的,也就是你Ctrl+Alt+F(1~6)調(diào)出的那個(gè)Console。我們以rc2為例,cat rc2:
start on runlevel 2
stop on runlevel [!2]
console output
script
set $(runlevel --set 2 || true)
if [ "$1" != "unknown" ]; then
PREVLEVEL=$1
RUNLEVEL=$2
export PREVLEVEL RUNLEVEL
fi
exec /etc/init.d/rc 2
end script
不去考慮細(xì)節(jié),只要注意到前兩行和倒數(shù)第二行就可以了??梢钥吹?,rc2文件是定義在發(fā)生運(yùn)行級(jí)別2的時(shí)候所要執(zhí)行的東西,核心就是這句:exec /etc/init.d/rc 2。這樣,我們就可以自然地過渡到下一個(gè)重要的目錄,/etc/init.d/了。
你可以ls /etc/init.d/看一下里面的內(nèi)容,對(duì)它有個(gè)大致的了解。/etc/init.d/中存放的是服務(wù)(services)或者任務(wù)(tasks)的執(zhí)行腳本。可以這么說,只要你安裝了一個(gè)程序(特別是服務(wù)程序daemon),它可以在系統(tǒng)啟動(dòng)的時(shí)候運(yùn)行,那么它必定會(huì)在/etc/init.d/中有一個(gè)腳本文件。我們還回到上面的rc2文件,它執(zhí)行了一個(gè)exec /etc/init.d/rc 2的命令。也就是說,給/etc/init.d/rc腳本傳遞了一個(gè)參數(shù)"2",讓它執(zhí)行。我們仔細(xì)查看一下rc腳本(很長,耐心點(diǎn)),能看到這樣的一段:
# Now run the START scripts for this runlevel.
# Run all scripts with the same level in parallel
for s in /etc/rc$runlevel.d/S*
這說明,當(dāng)給rc腳本傳遞一個(gè)數(shù)字參數(shù)"X"的時(shí)候,它在經(jīng)過一系列的設(shè)置后,將會(huì)開始執(zhí)行/etc/rcX.d/下S開頭的腳本。這就過渡到下一個(gè)目錄/etc/rcX.d/了。
進(jìn)入/etc/rcX.d/,ls -l /etc/rcX.d/看看有些什么內(nèi)容?哈哈,沒錯(cuò),都是一些到/etc/init.d/中腳本的符號(hào)鏈接。不同的是它們的開頭加上了S和一個(gè)數(shù)字。熟悉原本init的人應(yīng)該知道,S表示在啟動(dòng)時(shí)運(yùn)行,數(shù)字則表示執(zhí)行的先后順序。
這樣一來,Ubuntu upstart管理的ubuntu啟動(dòng)過程應(yīng)該就清楚了。梳理一下:1,內(nèi)核啟動(dòng)init 2,init找到/etc/event.d/rc-default文件,確定默認(rèn)的運(yùn)行級(jí)別(X) 3,觸發(fā)相應(yīng)的runlevel事件,開始運(yùn)行/etc/event.d/rcX 4,rcX運(yùn)行/etc/init.d/rc,傳入?yún)?shù)X 5,/etc/init.d/rc腳本進(jìn)行一系列設(shè)置,***運(yùn)行相應(yīng)的/etc/rcX.d/中的腳本6,/etc/rcX.d/中的腳本按事先設(shè)定的優(yōu)先級(jí)依次啟動(dòng),直至***給出登錄畫面(啟動(dòng)X服務(wù)器和GDM)
理解了這些,手動(dòng)配置開機(jī)服務(wù)的啟動(dòng)與否就很簡單了。Ubutnu默認(rèn)的啟動(dòng)級(jí)別是2,不想啟動(dòng)的程序,只要把相應(yīng)的符號(hào)鏈接從/etc/rc2.d/中刪去即可!
【編輯推薦】