0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

相比其他系統(tǒng)的內(nèi)核設(shè)計Linux是否已經(jīng)過時?

馬哥Linux運(yùn)維 ? 2017-11-29 17:25 ? 次閱讀

Linux 多年來取得的成績毋庸多言。但最近,reddit 上有人發(fā)起了一個話題,想知道 Linux 的內(nèi)核設(shè)計是否已經(jīng)過時,并得到了一些有趣的答案。

這位Ronis_BR的用戶提問大致如下:

Linux 是在 1992 年啟動的,一些特性到現(xiàn)在都沒有改變。我猜想最新操作系統(tǒng)內(nèi)核設(shè)計技術(shù)(如果存在…)應(yīng)該較之前有很大的進(jìn)步。那 Linux 內(nèi)核是否已經(jīng)過時?

與 Windows、macOS、FreeBSD 內(nèi)核的設(shè)計相比,Linux 內(nèi)核的設(shè)計有沒有在哪些方面比較先進(jìn)?(注意,重點是設(shè)計的先進(jìn),而不是哪一個更好)。

該話題引起了近 400 條回復(fù),大家紛紛發(fā)表了自己對內(nèi)核設(shè)計的看法,節(jié)選幾條不同的觀點:

ExoticMandibles:

“過時”?不存在的。Linux kernel 對現(xiàn)代內(nèi)核的設(shè)計其實是非常了解的,只是它選擇了保持傳統(tǒng)的形式。

內(nèi)核設(shè)計的核心在于“安全/穩(wěn)定”和“性能”之間的關(guān)系。Microkernels(微內(nèi)核)以性能為代價保證安全。如果你有極小的微內(nèi)核,那么它將具有相對較小的 API surface,使其難以被攻擊。而且當(dāng)你有一個錯誤的文件時,驅(qū)動程序崩潰而不占用內(nèi)核,可以無損重啟。優(yōu)越的穩(wěn)定性!優(yōu)越的安全性!一切很美好。

但這種方案的缺點是所有 IPC 永遠(yuǎn)且不可避免的開銷。如果你的程序想從文件加載數(shù)據(jù),則必須訪問文件系統(tǒng)驅(qū)動,這意味著 IPC 要處理進(jìn)程上下文切換和兩次 ring transitions 。然后,文件系統(tǒng)驅(qū)動要求內(nèi)核與硬件通信,這也意味著兩次 ring transitions。然后文件系統(tǒng)驅(qū)動發(fā)送其回復(fù),這意味著又一輪的兩次,以及另一次上下文切換??傞_銷:兩次上下文切換,兩次 IPC 調(diào)用和六次 ring transitions。非常貴!

宏內(nèi)核將所有設(shè)備驅(qū)動合攏到內(nèi)核中。所以當(dāng)出現(xiàn)一個錯誤的圖形驅(qū)動,就可以占用內(nèi)核,或者如果它有一個安全漏洞,那么可能被用來危及系統(tǒng)。但是,如果你的程序需要從磁盤加載某些東西,則會調(diào)用內(nèi)核,進(jìn)行 ring transitions,與硬件通話,計算結(jié)果,并返回結(jié)果,進(jìn)行另一個 ring transitions??傞_銷:兩次 ring transitions。便宜得多,也快得多!

簡而言之,微內(nèi)核是:“放棄性能來提高安全性和穩(wěn)定性”;宏內(nèi)核是:“保持性能,只要修復(fù)安全和穩(wěn)定性問題就可以了”。而目前,大家更愿意接受后者。

Scandalousmambo:

開發(fā)一個和Linux kernel 相同的系統(tǒng),從本質(zhì)上決定了它一旦設(shè)計出來就會“過時”。

KugelKurt:

盡管這里討論的大部分內(nèi)容都是關(guān)于微內(nèi)核與宏內(nèi)核的關(guān)系,但是最近的研究還涉及到編程語言。如果你今天啟動一個全新的內(nèi)核,那么就可能不會用 C 去寫。微軟的 Singularity 和 Midori 項目探討了用 C#托管代碼內(nèi)核的可行性。

Daemonpenguin:

有一些概念,在理論上可以提供更好的內(nèi)核設(shè)計。比如,理論上微內(nèi)核也有一些非常好的設(shè)計選擇,使得它們具有便攜性、可靠性和潛在的自我修正能力。

然而,無論理論多么好,人們總是會根據(jù)實際情況進(jìn)行設(shè)計。Linux 內(nèi)核擁有如此多的硬件支持,那么多公司支持開發(fā),其他內(nèi)核(不管設(shè)計得多炫酷)都不太可能趕得上。

例如,MINIX 具有良好的設(shè)計和一些很棒的功能,但硬件支持很少,幾乎沒有人為此平臺開發(fā)。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11213

    瀏覽量

    208736

原文標(biāo)題:Linux kernel 的設(shè)計是否已經(jīng)過時?

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    需要將TLV320aic3120使用在一個Linux3.0.35的系統(tǒng)中,請問是否有適應(yīng)于老內(nèi)核的驅(qū)動?

    現(xiàn)在需要將TLV320aic3120使用在一個Linux3.0.35的系統(tǒng)中,但是在官網(wǎng)上提供的驅(qū)動比較新,并不能用到老的系統(tǒng)中。 請問是否有適應(yīng)于老
    發(fā)表于 10-22 08:02

    Linux根文件系統(tǒng)的掛載過程

    Linux根文件系統(tǒng)(rootfs)是Linux系統(tǒng)中所有其他文件系統(tǒng)和目錄的起點,它是
    的頭像 發(fā)表于 10-05 16:50 ?233次閱讀

    詳解linux內(nèi)核的uevent機(jī)制

    linux內(nèi)核中,uevent機(jī)制是一種內(nèi)核和用戶空間通信的機(jī)制,用于通知用戶空間應(yīng)用程序各種硬件更改或其他事件,比如插入或移除硬件設(shè)備(如USB驅(qū)動器或網(wǎng)絡(luò)接口)。uevent表示
    的頭像 發(fā)表于 09-29 17:01 ?401次閱讀

    linux驅(qū)動程序如何加載進(jìn)內(nèi)核

    Linux系統(tǒng)中,驅(qū)動程序是內(nèi)核與硬件設(shè)備之間的橋梁。它們允許內(nèi)核與硬件設(shè)備進(jìn)行通信,從而實現(xiàn)對硬件設(shè)備的控制和管理。 驅(qū)動程序的編寫 驅(qū)動程序的編寫是
    的頭像 發(fā)表于 08-30 15:02 ?348次閱讀

    Linux內(nèi)核測試技術(shù)

    Linux 內(nèi)核Linux操作系統(tǒng)的核心部分,負(fù)責(zé)管理硬件資源和提供系統(tǒng)調(diào)用接口。隨著 Linux
    的頭像 發(fā)表于 08-13 13:42 ?417次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>測試技術(shù)

    Linux內(nèi)核中的頁面分配機(jī)制

    Linux內(nèi)核中是如何分配出頁面的,如果我們站在CPU的角度去看這個問題,CPU能分配出來的頁面是以物理頁面為單位的。也就是我們計算機(jī)中常講的分頁機(jī)制。本文就看下Linux內(nèi)核是如何管
    的頭像 發(fā)表于 08-07 15:51 ?216次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>中的頁面分配機(jī)制

    歡創(chuàng)播報 華為宣布鴻蒙內(nèi)核已超越Linux內(nèi)核

    1 華為宣布鴻蒙內(nèi)核已超越Linux內(nèi)核 ? 6月21日,在華為開發(fā)者大會上, HarmonyOS NEXT(鴻蒙NEXT)——真正獨(dú)立于安卓和iOS的鴻蒙操作系統(tǒng),正式登場。這是Ha
    的頭像 發(fā)表于 06-27 11:30 ?765次閱讀

    使用 PREEMPT_RT 在 Ubuntu 中構(gòu)建實時 Linux 內(nèi)核

    盟通技術(shù)干貨構(gòu)建實時Linux內(nèi)核簡介盟通技術(shù)干貨Motrotech如果需要在Linux中實現(xiàn)實時計算性能,進(jìn)而有效地將Linux轉(zhuǎn)變?yōu)镽TOS,那么大多數(shù)發(fā)行版都可以打上名為PREE
    的頭像 發(fā)表于 04-12 08:36 ?2114次閱讀
    使用 PREEMPT_RT 在 Ubuntu 中構(gòu)建實時 <b class='flag-5'>Linux</b> <b class='flag-5'>內(nèi)核</b>

    請問如何給STM32MP157上Linux5.4.31打?qū)崟r內(nèi)核補(bǔ)???

    版本對應(yīng)的實時內(nèi)核補(bǔ)丁。不知道Atmel公司是否有做好的實時內(nèi)核補(bǔ)丁,可以供用戶使用呢?如果沒有對應(yīng)的版本,我是否可以使用其他
    發(fā)表于 03-11 06:09

    linux內(nèi)核主要由哪幾個部分組成,作用是什么

    Linux內(nèi)核主要由以下幾個部分組成: 進(jìn)程管理:Linux內(nèi)核負(fù)責(zé)管理和調(diào)度系統(tǒng)中的進(jìn)程。它通過進(jìn)程調(diào)度算法來決定哪個進(jìn)程在什么時間運(yùn)行以
    的頭像 發(fā)表于 01-22 14:34 ?2568次閱讀

    RZ/G2L Linux系統(tǒng)如何添加新的內(nèi)核模塊

    RZ/G2L Linux系統(tǒng)的鏡像基于yocto構(gòu)建,本篇介紹如何添加新的內(nèi)核模塊。
    的頭像 發(fā)表于 01-04 12:19 ?1669次閱讀
    RZ/G2L <b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b>如何添加新的<b class='flag-5'>內(nèi)核</b>模塊

    獲取Linux內(nèi)核源碼的方法

    (ELF1/ELF1S開發(fā)板及顯示屏)Linux內(nèi)核是操作系統(tǒng)中最核心的部分,它負(fù)責(zé)管理計算機(jī)硬件資源,并提供對應(yīng)用程序和其他系統(tǒng)組件的訪問
    的頭像 發(fā)表于 12-13 09:49 ?609次閱讀
    獲取<b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>源碼的方法

    Linux內(nèi)核自解壓過程分析

    uboot完成系統(tǒng)引導(dǎo)以后,執(zhí)行環(huán)境變量bootm中的命令;即,將Linux內(nèi)核調(diào)入內(nèi)存中并調(diào)用do_bootm函數(shù)啟動內(nèi)核,跳轉(zhuǎn)至kernel的起始位置。
    的頭像 發(fā)表于 12-08 14:00 ?835次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>自解壓過程分析

    linux 查看網(wǎng)卡狀態(tài)是否開啟

    如何查看 Linux 網(wǎng)卡狀態(tài)是否開啟 在 Linux 系統(tǒng)中,我們可以使用一些命令來查看網(wǎng)卡狀態(tài)是否開啟。本文將詳細(xì)介紹如何使用這些命令來
    的頭像 發(fā)表于 11-17 10:31 ?2397次閱讀

    linux系統(tǒng)基礎(chǔ)入門教程

    1991年,由芬蘭學(xué)生林納斯·托瓦茲(Linus Torvalds)開始開發(fā)。與其他操作系統(tǒng)不同,Linux采用了開源的模式,這意味著任何人都可以查看、使用和修改其源代碼。 Linux
    的頭像 發(fā)表于 11-16 16:45 ?996次閱讀