出版時間:201005 出版社:人民郵電出版社 作者:Wolfgang Mauerer 頁數(shù):1038 譯者:郭旭
Tag標簽:無
內(nèi)容概要
本書討論了Linux內(nèi)核的概念、結(jié)構和實現(xiàn)。主要內(nèi)容包括多任務、調(diào)度和進程管理,物理內(nèi)存的管理以及內(nèi)核與相關硬件的交互,用戶空間的進程如何訪問虛擬內(nèi)存,如何編寫設備驅(qū)動程序,模塊機制以及虛擬文件系統(tǒng),Ext文件系統(tǒng)屬性和訪問控制表的實現(xiàn)方式,內(nèi)核中網(wǎng)絡的實現(xiàn),系統(tǒng)調(diào)用的實現(xiàn)方式,內(nèi)核對時間相關功能的處理,頁面回收和頁交換的相關機制以及審計的實現(xiàn)等。此外,本書借助內(nèi)核源代碼中最關鍵的部分進行講解,幫助讀者掌握重要的知識點,從而在運用中充分展現(xiàn)Linux系統(tǒng)的魅力?! ”緯m合Linux內(nèi)核愛好者閱讀。
作者簡介
作者:(德國)莫爾勒(Wolfgang Mauerer) 譯者:郭旭莫爾勒(Woflgang Mauerer),資深Linux專家,有數(shù)十年Linux開發(fā)經(jīng)驗。從1997年最初發(fā)表關于內(nèi)核的系列文章開始,他就醉心于解釋Linux核心的內(nèi)部機制、編寫相關的文檔,此外,他還著有LaTex排版方面的圖書,其撰寫的大量文章已經(jīng)被釋譯成7種語言。
書籍目錄
第1章 簡介和概述 1.1 內(nèi)核的任務 1.2 實現(xiàn)策略 1.3 內(nèi)核的組成部分 1.3.1 進程、進程切換、調(diào)度 1.3.2 UNIX進程 1.3.3 地址空間與特權級別 1.3.4 頁表 1.3.5 物理內(nèi)存的分配 1.3.6 計時 1.3.7 系統(tǒng)調(diào)用 1.3.8 設備驅(qū)動程序、塊設備和字符設備 1.3.9 網(wǎng)絡 1.3.10 文件系統(tǒng) 1.3.11 模塊和熱插拔 1.3.12 緩存 1.3.13 鏈表處理 1.3.14 對象管理和引用計數(shù) 1.3.15 數(shù)據(jù)類型 1.3.16 本書的局限性 1.4 為什么內(nèi)核是特別的 1.5 行文注記 1.6 小結(jié) 第2章 進程管理和調(diào)度 2.1 進程優(yōu)先級 2.2 進程生命周期 2.3 進程表示 2.3.1 進程類型 2.3.2 命名空間 2.3.3 進程ID號 2.3.4 進程關系 2.4 進程管理相關的系統(tǒng)調(diào)用 2.4.1 進程復制 2.4.2 內(nèi)核線程 2.4.3 啟動新程序 2.4.4 退出進程 2.5 調(diào)度器的實現(xiàn) 2.5.1 概觀 2.5.2 數(shù)據(jù)結(jié)構 2.5.3 處理優(yōu)先級 2.5.4 核心調(diào)度器 2.6 完全公平調(diào)度類 2.6.1 數(shù)據(jù)結(jié)構 2.6.2 CFS操作 2.6.3 隊列操作 2.6.4 選擇下一個進程 2.6.5 處理周期性調(diào)度器 2.6.6 喚醒搶占 2.6.7 處理新進程 2.7 實時調(diào)度類 2.7.1 性質(zhì) 2.7.2 數(shù)據(jù)結(jié)構 2.7.3 調(diào)度器操作 2.8 調(diào)度器增強 2.8.1 SMP調(diào)度 2.8.2 調(diào)度域和控制組 2.8.3 內(nèi)核搶占和低延遲相關工作 2.9 小結(jié) 第3章 內(nèi)存管理 3.1 概述 3.2 (N)UMA模型中的內(nèi)存組織 3.2.1 概述 3.2.2 數(shù)據(jù)結(jié)構 3.3 頁表 3.3.1 數(shù)據(jù)結(jié)構 3.3.2 頁表項的創(chuàng)建和操作 3.4 初始化內(nèi)存管理 3.4.1 建立數(shù)據(jù)結(jié)構 3.4.2 特定于體系結(jié)構的設置 3.4.3 啟動過程期間的內(nèi)存管理 3.5 物理內(nèi)存的管理 3.5.1 伙伴系統(tǒng)的結(jié)構 3.5.2 避免碎片 3.5.3 初始化內(nèi)存域和結(jié)點數(shù)據(jù)結(jié)構 3.5.4 分配器API 3.5.5 分配頁 3.5.6 釋放頁 3.5.7 內(nèi)核中不連續(xù)頁的分配 3.5.8 內(nèi)核映射 3.6 slab分配器 3.6.1 備選分配器 3.6.2 內(nèi)核中的內(nèi)存管理 3.6.3 slab分配的原理 3.6.4 實現(xiàn) 3.6.5 通用緩存 3.7 處理器高速緩存和TLB控制 3.8 小結(jié) 第4章 進程虛擬內(nèi)存 4.1 簡介 4.2 進程虛擬地址空間 4.2.1 進程地址空間的布局 4.2.2 建立布局 4.3 內(nèi)存映射的原理 4.4 數(shù)據(jù)結(jié)構 4.4.1 樹和鏈表 4.4.2 虛擬內(nèi)存區(qū)域的表示 4.4.3 優(yōu)先查找樹 4.5 對區(qū)域的操作 4.5.1 將虛擬地址關聯(lián)到區(qū)域 4.5.2 區(qū)域合并 4.5.3 插入?yún)^(qū)域 4.5.4 創(chuàng)建區(qū)域 4.6 地址空間 4.7 內(nèi)存映射 4.7.1 創(chuàng)建映射 4.7.2 刪除映射 4.7.3 非線性映射 4.8 反向映射 4.8.1 數(shù)據(jù)結(jié)構 4.8.2 建立逆向映射 4.8.3 使用逆向映射 4.9 堆的管理 4.10 缺頁異常的處理 4.11 用戶空間缺頁異常的校正 4.11.1 按需分配/調(diào)頁 4.11.2 匿名頁 4.11.3 寫時復制 4.11.4 獲取非線性映射 4.12 內(nèi)核缺頁異?! ?.13 在內(nèi)核和用戶空間之間復制數(shù)據(jù) 4.14 小結(jié) 第5章 鎖與進程間通信第6章 設備驅(qū)動程序 第7章 模塊 第8章 虛擬文件系統(tǒng) 第9章 Ext文件系統(tǒng)族 第10章 無持久存儲的文件系統(tǒng) 第11章 擴展屬性和訪問控制表 第12章 網(wǎng)絡 第13章 系統(tǒng)調(diào)用第14章 內(nèi)核活動 第15章 時間管理 第16章 頁緩存和塊緩存第17章 數(shù)據(jù)同步第18章 頁面回收和頁交換 第19章 審計 附錄A 體系結(jié)構相關知識 附錄B 使用源代碼 附錄C 有關C語言的注記 附錄D 系統(tǒng)啟動 附錄E ELF二進制格式 附錄F 內(nèi)核開發(fā)過程 參考文獻
章節(jié)摘錄
插圖:內(nèi)核很神奇,但歸根結(jié)底它只是一個大的C程序,帶有一些匯編代碼(不時出現(xiàn)很少量的“黑巫術”)。是什么使得內(nèi)核如此吸引人?原因有幾個。首要一點在于,內(nèi)核是由世界上最好的程序員編寫的,源代碼可以證實這一點。其結(jié)構良好,細節(jié)一絲不茍,巧妙的解決方案在代碼中處處可見。一言以蔽之:內(nèi)核應該是什么樣子,它現(xiàn)在就是什么樣子。但這并不意味著內(nèi)核是應用教科書風格的程序設計方法學得出的產(chǎn)品。盡管內(nèi)核采用了設計得非常干凈的抽象,以保持代碼的模塊化和易管理性,但這一點與內(nèi)核的其他方面混合起來,使得代碼非常有趣和獨特。在必要的情況下,內(nèi)核會以上下文相關的方式重用比特位置,多次重載結(jié)構成員,從指針已經(jīng)對齊的部分壓榨出又一個存儲位,自由地使用goto語句,還有很多其他東西,這些都會使任何強調(diào)結(jié)構的程序員因痛苦而尖叫。教科書答案中難以想象的那些技巧,對于實現(xiàn)能夠在真正的現(xiàn)實世界中正常工作的內(nèi)核不僅是有益的,甚至是必需的。正是因為找到了一條在內(nèi)核完全對立的兩面之間保持平衡的路徑,內(nèi)核才如此令人興味盎然、富有挑戰(zhàn)性并且妙趣橫生!頌揚了內(nèi)核源代碼之后,還有許多不同于用戶層程序的嚴肅問題需要說明??谡{(diào)試內(nèi)核通常要比調(diào)試用戶層程序困難。對后者來說有大量的調(diào)試器可用,而對于后者來說調(diào)試器的實現(xiàn)難度要高得多。附錄B討論了在內(nèi)核開發(fā)中使用調(diào)試器的各種技巧,但與用戶層對應的方法相比都需要更多的工作??趦?nèi)核提供了許多輔助函數(shù),類似于用戶空間的c語言庫,但內(nèi)核領域中的東西總是樸素得多??谟脩魧討贸绦虻腻e誤可能會導致段錯誤(segmentation fault)或內(nèi)存轉(zhuǎn)儲(core dump),但內(nèi)核錯誤會導致整個系統(tǒng)故障。甚至更糟的是:內(nèi)核會繼續(xù)運行,在錯誤發(fā)生若干小時之后系統(tǒng)離奇地崩潰。如上所述,因為在內(nèi)核空間調(diào)試比用戶層應用程序更困難,所以在內(nèi)核代碼投入使用之前要進行更多的考慮??诒仨毧紤]到內(nèi)核運行的許多體系結(jié)構上根本不支持非對齊的內(nèi)存訪問。由于編譯器插入的填充(padding)字段,也會影響到數(shù)據(jù)結(jié)構在不同體系結(jié)構之間的可移植性。附錄C會進一步討論這個問題??谒械膬?nèi)核代碼都必須是并發(fā)安全的。由于對多處理器計算機的支持,Linux內(nèi)核代碼必須是可重入和線程安全的。也就是說,程序必須允許同時執(zhí)行,而數(shù)據(jù)必須針對并行訪問進行保護??趦?nèi)核代碼必須在小端序和大端序計算機上都能夠工作??诖蠖鄶?shù)的體系結(jié)構根本不允許在內(nèi)核中執(zhí)行浮點計算,因此計算需要想辦法用整型來替代。后面讀者會看到如何處理這些問題。
媒體關注與評論
“這本書敘述深入淺出,內(nèi)容全面詳盡,是學習掌握Lmux所有內(nèi)在工作機理最理想的參考書之一”。 ——C.Glovanni,資深Linux程序開發(fā)者
編輯推薦
《深入Linux內(nèi)核架構》編輯推薦:眾所周知,Linux操作系統(tǒng)的源代碼復雜、文檔少,對程序員的要求高,要想看懂這些代碼并不是一件容易事?!渡钊隠inux內(nèi)核架構》結(jié)合內(nèi)核版本2.6.24源代碼中最關鍵的部分。深入討論Lirnux內(nèi)核的概念、結(jié)構和實現(xiàn)。具體包括進程管理和調(diào)度、虛擬內(nèi)存、進程間通信、設備驅(qū)動程序、虛擬文件系統(tǒng)、網(wǎng)絡、時間管理、數(shù)據(jù)同步等。《深入Linux內(nèi)核架構》引導你閱讀內(nèi)核源代碼,熟悉Linux妍有的內(nèi)在工作機理,充分展現(xiàn)Linux系統(tǒng)的魅力。《深入Linux內(nèi)核架構》適合Linux系統(tǒng)編程人員、系統(tǒng)管理者以及Linux愛好者學習使用。內(nèi)容全面深入全球開源社區(qū)集體智慧結(jié)晶領略Linux內(nèi)核的絕美風光
圖書封面
圖書標簽Tags
無
評論、評分、閱讀與下載