Linux內核實戰(二)- 操做系統概覽

image

不知道你有沒有產生過這些疑問:程序員

桌面上的圖標究竟是啥?憑啥我在鼠標上一雙擊,就會出來一些不可描述的畫面?都是從哪裏跑出來的?
憑什麼我在鍵盤上噼裏啪啦地敲,某個位置就會顯示我想要的那些字符?網絡

電腦怎麼知道我鼠標點擊的是這個地方,又是怎麼知道我要輸入的是這個地方?架構

我在鍵盤上點「a」,是誰在顯示器上畫出「a」這個圖像呢?併發

爲何我一回車,這些字符就發到遙遠的另一臺機器上去了?函數

別小看「雙擊鼠標打開聊天軟件」這樣一個簡單的操做,它幾乎涵蓋了操做系統的全部功能。咱們就從這個熟悉的操做,來認識陌生的操做系統。操作系統

操做系統其實就像一個軟件外包,內核就至關於這家外包公司的老闆。因此接下來請你將本身的角色切換成這家軟件外包公司的老闆,設身處地地去理解操做系統是如何協調各類資源,幫客戶作成事情的。blog

image

從此所說的「用戶」,都是指操做系統的用戶,「客戶」則是指外包公司的客戶,這二者是對應的。接口

1 雙擊運行軟件,觸動了哪些硬件呢

1.1 鼠標和鍵盤

計算機的輸入設備。進程

用戶想要告訴計算機應該作什麼,都是經過這兩個設備。事件

若是是一家外包公司,怎麼才能知道客戶的需求呢?你須要配備銷售、售前等角色,專門負責和客戶對接,把客戶需求拿回來,咱們把這些人統稱爲客戶對接員。你能夠跟客戶說,有什麼事兒都找對接員。

1.2 屏幕

也就是顯示器,是計算機的輸出設備,將計算機處理用戶請求後的結果反饋給客戶。

顯示器上面顯示的東西是由顯卡控制的。

不管是顯示器仍是顯卡,這裏都有個「座標」的概念,也就是說,什麼圖像在哪一個座標,都是定義好了才畫上去的。原本在某個座標畫了一個鼠標箭頭,當接到鼠標移動的事件以後,你應該按相同的方向,按照必定的比例(鼠標靈敏度),在屏幕的某個座標再畫一個鼠標箭頭。

做爲外包公司,當客戶給你提了需求,無論你作仍是不作,最終作成什麼樣,你都須要給客戶反饋,因此你要配備交付人員,將作好的需求展現給他們看。

1.3 輸入設備驅動

其實就是客戶對接員。有時候新插上一個鼠標的時候,會彈出一個通知你安裝驅動,這就是操做系統這家外包公司給你配備對接人員呢。當客戶告訴對接員需求的時候,對於操做系統來說,輸入設備會發送一箇中斷。這個概念很好理解。客戶確定但願外包公司把正在作的事情都停下來服務它。因此,這個時候客戶發送的需求就被稱爲中斷事件(Interrupt Event)。

1.4 輸出設備驅動

顯卡會有顯卡驅動,在操做系統中稱爲輸出設備驅動,也就是上面說的交付人員。

2 從點擊程序,窺探OS全貌

有了客戶對接員和交付人員,外包公司就能夠處理用戶「在桌面上點擊QQ圖標」的事件了。

首先,鼠標雙擊會觸發一箇中斷,這至關於客戶告知客戶對接員「有了新需求,須要處理一下」。你會事先把處理這種問題的方法教給客戶對接員。在操做系統裏面就是調用中斷處理函數。操做系統發現雙擊的是一個圖標,就明白了用戶的原始訴求,準備運行QQ和別人聊天。

你會發現,運行QQ是一件大事,由於未來的一段時間,用戶要一直和QQ進行交互。

這就至關於大家公司接了一個大單,而不是處理零星的客戶需求,這個時候應該單獨立項。一旦立了項,之後與這個項目有關的事情,都由這個項目組來處理。

2.1文件管理系統

立項可不能隨便立,必定要有一個項目執行計劃書,說明這個項目打算怎麼作,一步一步如何執行,遇到什麼狀況應該怎麼辦等等。

換句話說,對QQ這個程序來講,它能作哪些事情,每一個事情怎麼作,先作啥後作啥,都已經做爲程序邏輯寫在程序裏面,而且編譯成爲二進制了。這個程序就至關於項目執行計劃書。

電腦上的程序有不少,它們都以二進制文件的形式保存在硬盤上。硬盤是個物理設備,要按照規定格式化成爲文件系統,才能存放這些程序。文件系統須要一個系統進行統一管理,稱爲文件管理子系統(File Management Subsystem)。

2.2 進程與程序

對於大家公司,項目立得多了,項目執行計劃書也會不少,一樣須要有個統一保存文件的檔案庫,並且須要有序地管理起來。

當你從資料庫裏面拿到這個項目執行計劃書,接下來就須要開始執行這個項目了。項目執行計劃書是靜態的,項目的執行是動態的。

同理,當操做系統拿到QQ的二進制執行文件的時候,就能夠運行這個文件了。

  • QQ的二進制文件是靜態的,稱爲程序(Program),
  • 運行起來的QQ,是不斷進行的,稱爲進程(Process)。

2.3 系統調用

你會發現,一個項目要想順暢進行,須要用到公司的各類資源,好比說蓋個公章、開個證實、申請個會議室、打印個材料等等。

這裏有個兩難的權衡

  • 資源有限,甚至是涉及機密的,不能由項目組濫取濫用
  • 效率,咱是一個私營企業,保證項目申請資源的時候只跑一次,這樣才能比較高效。

爲了平衡這一點,一方面涉及核心權限的資源,仍是應該被公司嚴格把控,審批了才能用;

另一方面,爲了提升效率,最好有個統一的辦事大廳,明文列出提供哪些服務,誰須要能夠來申請,而後就會有迴應。

在操做系統中,也有一樣的問題。

例如多個進程都要往打印機上打印文件,若是隨便亂打印進程,就會出現一樣一張紙,第一行是A進程輸出的文字,第二行是B進程輸出的文字,全亂套了。因此,打印機的直接操做是放在操做系統內核裏面的,進程不能隨便操做。可是操做系統也提供一個辦事大廳,也就是系統調用(System Call)。

系統調用也能列出來提供哪些接口能夠調用,進程有須要的時候就能夠去調用。

這其中,立項是辦事大廳提供的關鍵服務之一。一樣,任何一個程序要想運行起來,就須要調用系統調用,建立進程。

2.4 進程管理系統

一旦項目正式立項,就要開始執行,就要成立項目組,將開發人員分配到這個項目組,按照項目執行計劃書一步一步執行。

爲了管理這個項目,咱們還須要一個項目經理、一套項目管理流程、一個項目管理系統,例如程序員比較熟悉的Jira。若是項目多,可能一個開發人員須要同時執行多個項目,這就要考驗項目經理的調度能力了。

在操做系統中,進程的執行也須要分配CPU進行執行,也就是按照程序裏面的二進制代碼一行一行地執行。

因而,爲了管理進程,咱們還須要一個進程管理子系統(Process Management Subsystem)。若是運行的進程不少,則一個CPU會併發運行多個進程,也就須要CPU的調度能力了。

2.5 內存管理系統

每一個項目都有本身的私密資料,這些資料不能被其餘項目組看到。這些資料主要是項目在執行的過程當中,產生的不少中間成果,例如架構圖、流程圖。

執行過程當中,不免要在白板上或者本子上寫寫畫畫,若是不一樣項目的辦公空間不隔離,一方面,項目的私密性不能獲得保證,A項目的細節,B項目也能看到;另外一方面,項目之間會相互干擾,A項目組的人剛在白板上畫了一個架構圖,出去上個廁所,結果B項目組的人就給擦了。

若是把不一樣的項目組分配到不一樣的會議室,就解決了這個問題。固然會議室是有限的,須要有人管理和分配,而且須要一個會議室管理系統。

在操做系統中,不一樣的進程有不一樣的內存空間,可是整個電腦內存就這麼點兒,因此須要統一的管理和分配,這就須要內存管理子系統(Memory Management Subsystem)。

若是想直觀地瞭解QQ如何使用CPU和內存,能夠打開任務管理器,你就能看到QQ這個進程耗費的CPU和內存。

項目執行的時候,有了必定的成果,就要給客戶演示。例如客戶說要作個應用,咱們作出來了要給客戶看看,若是客戶說哪裏須要改,能夠根據客戶的需求再改,這就須要交付人員了。

QQ啓動以後,有一部分代碼會在顯示器上畫一個對話框,而且將鍵盤的焦點放在了輸入框裏面。CPU根據這些指令,就會告知顯卡驅動程序,將這個對話框畫出來。

因而使用QQ的用戶就會很開心地發現,他能和別人開始聊天了。

當用戶經過鍵盤噼裏啪啦打字的時候,鍵盤也是輸入設備,也會觸發中斷,通知相應的輸入設備驅動程序。

咱們假設用戶輸入了一個「a」。這就像客戶提出了新的需求給客戶對接員。客戶對接員收到需求後,由於是對接這個項目的,於是就回來報告,客戶提新需求了,項目組須要處理一下。項目執行計劃書裏面通常都會有當遇到何種需求應該怎麼作的規定,項目組就按這個規定作了,而後讓交付人員再去客戶那裏演示就好了。

對於QQ來說,因爲鍵盤閃啊閃的焦點在QQ這個對話框上,於是操做系統知道,這個事件是給這個進程的。QQ的代碼裏面確定有遇到這種事件如何處理的代碼,就會執行。通常是記錄下客戶的輸入,而且告知顯卡驅動程序,在那個地方畫一個「a」。顯卡畫完了,客戶看到了,就以爲本身的輸入成功了。

當用戶輸入完畢以後,回車一下,仍是會經過鍵盤驅動程序告訴操做系統,操做系統仍是會找到QQ,QQ會將用戶的輸入發送到網絡上。QQ進程是不能直接發送網絡包的,須要調用系統調用,內核使用網卡驅動程序進行發送。

這就像客戶對接員接到一個需求,可是這個需求須要和其餘公司溝通,這就須要依靠公司的對外合做部,對外合做部在辦事大廳有專門的窗口,很是方便。

image

總結

到這裏,一個外包公司大部分的職能部門都湊齊了。你能夠對應着下圖的操做系統內核體系結構,回顧一下它們是如何組成一家公司的。

QQ的運行過程,只是一個簡單的比喻。在後面的章節中,我會展開講述每一個部分是怎麼工做的,最後我會再將這個過程串起來,這樣你就能瞭解操做系統的全貌了。

操做系統內核體系結構圖

image

參考

趣談Linux操做系統

相關文章
相關標籤/搜索