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

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

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

為何Linus一個(gè)人就能寫出這么強(qiáng)的系統(tǒng)

CodeSheep ? 來源:CodeSheep ? 2023-05-12 10:05 ? 次閱讀

大家好,我是程序羊。一個(gè)多月前我曾寫過一篇文章聊了聊CentOS這款Linux系統(tǒng)在停服后的一些平替問題。

我清晰地記得當(dāng)時(shí)評(píng)論區(qū)有一位小伙伴提出了一個(gè)這樣的問題:

“為什么別人信手拈來就能寫出一個(gè)操作系統(tǒng),而我們這么多大公司、那么多程序員就不行?”

93b9106e-f004-11ed-90ce-dac502259ad0.png

其實(shí)當(dāng)時(shí)看到這條評(píng)論時(shí)還蠻想寫一些文字詳細(xì)回復(fù)一下的,但是受限于時(shí)間和評(píng)論區(qū)篇幅的問題,當(dāng)時(shí)也就沒能展開細(xì)寫。

畢竟一個(gè)操作系統(tǒng)的產(chǎn)生、發(fā)展和繁榮涉及到的問題還挺多的,比如環(huán)境、比如開源、比如生態(tài),甚至還包括一些歷史進(jìn)程和天時(shí)地利的影響,所以肯定不是說全靠某一個(gè)人信手拈來就能搞定的。

那關(guān)于這個(gè)問題呢,還記得之前刷知乎時(shí)看到過一個(gè)非常類似的討論,印象比較深。

93ef5f98-f004-11ed-90ce-dac502259ad0.jpg

其中有一位網(wǎng)友的回答還是非常專業(yè)的(zhihu.com/question/63187737/answer/1415937231),或許可以提供一些參考,所以這里也分享給大家,大家如果有一些其他想法或者見解,也歡迎在評(píng)論區(qū)分享交流。以下是正文。

Linus研究生時(shí)期開始寫操作系統(tǒng)(大約是91年),那時(shí)候個(gè)人電腦(PC)雖然興起一些年了,但是還只是小部分程序員和狂熱愛好者的玩具。

硬件基本上都靠自己攢,軟件也是用開源系統(tǒng)各種魔改。所以普通人根本沒有折騰PC的動(dòng)力和理由。

Unix已經(jīng)霸占了許多生產(chǎn)力場(chǎng)景,唯一的缺點(diǎn)就是貴,而且很多發(fā)行版是閉源的。個(gè)人用戶根本不要考慮。

那時(shí)候Linus自己攢了一套386,但是找不到好用,廉價(jià)/免費(fèi)的操作系統(tǒng)用。

當(dāng)時(shí)社區(qū)里當(dāng)然也有一票免費(fèi)且開源的系統(tǒng),但是要不就是兼容性差,要不就是各種坑,要不就是沒軟件,總之各種各樣的問題。

而兼容性是最主要的問題,那時(shí)候的CPU不像現(xiàn)在的流行架構(gòu)就那么兩種(x86,ARM),那時(shí)候叫的上名的架構(gòu)有十幾種,所以操作系統(tǒng)的兼容性是非常重要的。

Linus開始自學(xué)操作系統(tǒng),發(fā)現(xiàn)了一本很好的教材《操作系統(tǒng):設(shè)計(jì)與實(shí)現(xiàn)》,然后花了一個(gè)暑假看完,開始自己寫操作系統(tǒng)。

《操作系統(tǒng):設(shè)計(jì)與實(shí)現(xiàn)》這本書的作者是塔雷鮑姆,寫書的時(shí)候已經(jīng)是業(yè)界大牛了,他在大學(xué)為了教學(xué)操作系統(tǒng),但苦于學(xué)生買不起太貴的Unix發(fā)行版,于是自己寫了一個(gè)兼容Unix標(biāo)準(zhǔn)操作系統(tǒng)(主要是兼容POSIX標(biāo)準(zhǔn)),叫Minix(名字上就很對(duì)仗,Universe - mini)。

Minix這個(gè)系統(tǒng)就是為了教學(xué)而生的,只要買了這本書,就免費(fèi)郵寄一份Minix源代碼。

Minix為了方便教學(xué),保持代碼的簡(jiǎn)潔,塔雷鮑姆拒絕向里面添加太多復(fù)雜的功能。所以Minix雖然實(shí)現(xiàn)得優(yōu)雅,但是社區(qū)的玩家要自己日常用,要魔改很多東西。

對(duì)了,Minix是微內(nèi)核的。對(duì),微內(nèi)核的概念存在幾十年了,而不是2019年誕生的。

微內(nèi)核的結(jié)構(gòu)非常優(yōu)雅,文件系統(tǒng),內(nèi)存管理,硬件驅(qū)動(dòng)都是以進(jìn)程形式存在的,而不是內(nèi)核代碼,這意味著驅(qū)動(dòng)掛了不會(huì)帶著內(nèi)核一起掛。缺點(diǎn)就是系統(tǒng)調(diào)用開銷太大,以至于慢到無法接受。所以現(xiàn)在的桌面系統(tǒng),沒有純微內(nèi)核的。

而對(duì)于教學(xué)系統(tǒng)來說,微內(nèi)核不是問題,畢竟是教學(xué),不是生產(chǎn)工具。

社區(qū)和Linus都很喜歡Minix,但是都不滿足于Minix作者因?yàn)榻虒W(xué)目的而放棄兼容性和可擴(kuò)展性。于是Linus在自己運(yùn)行Minix的PC開始了Linux的開發(fā)。Linux是宏內(nèi)核的。

Linux本來不叫Linux,Linus是一個(gè)很內(nèi)向的人,不好意思取這么自戀的名字,但是合作者強(qiáng)烈建議用這個(gè)名字,所以就用了,x代表unix的聯(lián)系(都兼容POSIX)。提一句,Unix不是為開源和免費(fèi)而生的,而是為商業(yè)而生的,但是Unix的發(fā)展催生了最好的開源環(huán)境(比如GNU)。

注意,這幾年的社區(qū),屬于“軍閥混戰(zhàn)”,大家都缺一款好用的免費(fèi)操作系統(tǒng),但并不只是Linus想到要解決這個(gè)問題,理查德斯托曼領(lǐng)導(dǎo)的GNU組織在90年代就一直醞釀一款免費(fèi)的操作系統(tǒng),因?yàn)樗麄兊哪康氖桥c商業(yè)的Unix對(duì)抗,光有一個(gè)GCC編譯器還不夠,還需要有自己的操作系統(tǒng)。

社區(qū)里各種技術(shù)人員也對(duì)GNU的操作系統(tǒng)非常期待,但是這玩意兒難產(chǎn)了。直到很久之后,Linux流行起來后,依然沒做出來。

最開始的Linux版本,只有幾千行代碼,現(xiàn)在基礎(chǔ)扎實(shí)的CS本科生,花一段時(shí)間都可以看懂,甚至有些OS教材就是用Linux最初的版本來教學(xué)的,比如哈工大李志軍的課程。

Linus從一開始就不斷在minix論壇上發(fā)布自己的進(jìn)展,搞得論壇上一堆人非常感興趣,于是許多人加入了開發(fā),這時(shí)候Linus用郵件接收每個(gè)人的代碼,然后手動(dòng)合并。

沒過一段時(shí)間,minix論壇上就全是討論Linux的了,雖然塔雷鮑姆不是個(gè)小氣的人,但是這么搞也讓塔雷鮑姆很不爽。

不久之后Linus和塔雷鮑姆之間爆發(fā)了一次沖突。塔雷鮑姆在論壇上寫了一篇文章,論證微內(nèi)核與宏內(nèi)核的優(yōu)缺點(diǎn),其實(shí)主要是攻擊宏內(nèi)核,說宏內(nèi)核除了性能好點(diǎn),全是缺點(diǎn),說Linux過時(shí)了。

Linus是脾氣暴躁的人,在技術(shù)問題上從不妥協(xié)。于是開始嘲諷minix。Linux的可移植性比minix更好,而且免費(fèi)開源(minix需要買書后獲得)。

然后來來去去吵了很多次。只是他們兩個(gè)當(dāng)時(shí)誰也沒想到,這次論壇上的口水戰(zhàn)會(huì)成為幾十年后人們依然提起的操作系統(tǒng)之爭(zhēng)。

Linus并不恨塔雷鮑姆,他說后來有一次去了塔雷鮑姆的演講,完了之后拿著那本書想要塔雷鮑姆的簽名,但是沒有等到人。

我想Linus多少還是尊敬他的,畢竟是自己學(xué)習(xí)操作系統(tǒng)的領(lǐng)路人。

在Linus和社區(qū)人員的努力下,通過擴(kuò)展GCC支持Linux,Linux也兼容了越來越多的平臺(tái)。其他各類軟件移植到Linux也就變得容易了,尤其是在那個(gè)許多軟件以源代碼方式發(fā)行的時(shí)代,只要有對(duì)應(yīng)平臺(tái)的編譯器,編譯一次就算移植好了。

趕上PC發(fā)展的浪潮,但還不夠,畢竟蘋果微軟不是好對(duì)付的,商業(yè)操作系統(tǒng)的易用性依然很強(qiáng)。

但是Linux開始被各類企業(yè)青睞了,因?yàn)椴皇敲總€(gè)企業(yè)都有錢花高價(jià)買一套Unix來用,或者是更貴的軟件+硬件一體的大型機(jī)來用。Linux讓他們看到了省錢的希望。

GNU開始支持Linux,Linux成為了GNU的官方操作系統(tǒng),所以現(xiàn)在叫GNU/Linux??梢哉fLinux和GCC幾乎是最偉大的兩個(gè)開源項(xiàng)目。它們合起來就更強(qiáng)悍了。

GCC讓軟件方便移植,Linux軟件生態(tài)就好了,軟件生態(tài)好了用戶就多,用戶多了就讓硬件公司眼饞,各路硬件公司都為L(zhǎng)inux開發(fā)驅(qū)動(dòng)和各種擴(kuò)展,以支持自家硬件,這樣用戶就更多。這個(gè)倍增效應(yīng)是很強(qiáng)的。

Linus在項(xiàng)目達(dá)到一定規(guī)模后就不再親自寫代碼了,主要是合并代碼,畢竟全球那么多人提交代碼,他一個(gè)人審核合并就夠忙了,親自寫代碼也沒時(shí)間。

直到有一天他覺得忙不過來了,審核代碼會(huì)遇到很多傻逼代碼和開發(fā)者,于是他開發(fā)了現(xiàn)在最流行的版本控制工具,git,字面意思就是飯桶。

從整個(gè)發(fā)展歷程來看,Linux在幾個(gè)十字路口都做了非常精準(zhǔn)的選擇。

從1991年0.0.1版到1994年1.0版,這期間Linux進(jìn)行了極其快速的迭代,社區(qū)玩家在使用中給出了寶貴的意見,最好的測(cè)試就是讓用戶去測(cè)試,這保證所有的更新都是實(shí)際有效的。

要知道,Linus在1991年開始開發(fā)時(shí),根本沒想過Linux有一天能改變世界,那個(gè)時(shí)候,他跟所有的社區(qū)玩家一樣,期待著GNU的系統(tǒng),所以他在論壇上解釋,做Linux只是一個(gè)業(yè)余愛好,最多用來填補(bǔ)GNU系統(tǒng)出來之前的這段空白時(shí)間。

但GNU由于各種名譽(yù)加身,導(dǎo)致目標(biāo)定得很高,于是項(xiàng)目一直延期,同時(shí)市面上的系統(tǒng)也在發(fā)展,GNU又繼續(xù)調(diào)高目標(biāo),然后繼續(xù)延期,最后難產(chǎn)。

而Linus從一開始,就沒什么心理壓力,每一點(diǎn)成果都在社區(qū)上公布,快速獲得反饋,然后及時(shí)調(diào)整。這種開發(fā)方式無意中就超越了GNU的閉門造車。

RedHat這種系統(tǒng)免費(fèi),服務(wù)收費(fèi)的模式也取得了成功,這大大激勵(lì)了其他發(fā)行版開發(fā)商的信心。目前Linux的發(fā)行版,至少幾百個(gè)吧。

96年2.0版發(fā)布,開始支持多核CPU,這個(gè)重要的更新,讓很多企業(yè)開始考慮Linux。

之后幾年Linux在服務(wù)器的份額快速上升。

03年2.6版發(fā)布,稍微了解過Linux的人都只要這意味著什么。2.6版本跨越03年-11年,中間有許多小版本更新。2.6版意味著Linux第一次成為真正具有了高穩(wěn)定性,高可用性,高可伸縮性的工業(yè)級(jí)別操作系統(tǒng)。

05年Git誕生,Linus和核心團(tuán)隊(duì)摸也索出一套穩(wěn)定實(shí)用的合作開發(fā)方式。

之后就是遍地開花的發(fā)展歷程了。

不得不說,他對(duì)操作系統(tǒng)發(fā)展方向的把控是精準(zhǔn)的。

總結(jié)一下,Linux的成功,以下幾個(gè)條件必不可少:

Linus強(qiáng)大的開發(fā)能力

Linus的項(xiàng)目管理能力

Linus對(duì)操作系統(tǒng)發(fā)展方向的把控

一個(gè)群雄割據(jù),缺乏免費(fèi)好用的操作系統(tǒng)的時(shí)代。

一個(gè)不僅群雄割據(jù),缺乏免費(fèi)好用的操作系統(tǒng),而且程序語言,操作系統(tǒng)理論,編譯器技術(shù)發(fā)展到一定程度,個(gè)人PC持續(xù)發(fā)展的時(shí)代。

GNU的系統(tǒng)沒做出來

Minix死守著『教育』不放

GNU的支持

全世界硬件廠商的支持

全世界軟件廠商的支持

全世界開源開發(fā)者的巨大貢獻(xiàn)

最后再總結(jié)一下,一個(gè)人的命運(yùn),當(dāng)然要靠自我奮斗,但也要考慮到歷史的進(jìn)程。

審核編輯 :李倩

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

    關(guān)注

    87

    文章

    11327

    瀏覽量

    209966
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6859

    瀏覽量

    123502
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4808

    瀏覽量

    68815

原文標(biāo)題:為何 Linus 一個(gè)人就能寫出這么強(qiáng)的系統(tǒng),而我們卻做不出來?

文章出處:【微信號(hào):CodeSheep,微信公眾號(hào):CodeSheep】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    專家:10年后每個(gè)人需要兩臺(tái)機(jī)器

    人形機(jī)器現(xiàn)在已經(jīng)開始在很多場(chǎng)景中有應(yīng)用,比如迎賓機(jī)器、送菜機(jī)器等。 據(jù)第財(cái)經(jīng)報(bào)道,上海理工大學(xué)教授、卓益得機(jī)器創(chuàng)始
    的頭像 發(fā)表于 12-05 14:36 ?555次閱讀

    快速了解CAN通訊原理及應(yīng)用

    張圖看懂CAN總線的原理 圖1 CAN通信原理 參考上圖,簡(jiǎn)單來說CAN總線就如兩根黃線,通信的原理就好比開個(gè)電話會(huì)議,大家都同時(shí)撥進(jìn)來,然后有各種不同的狀態(tài),比如:一個(gè)人說話,其
    的頭像 發(fā)表于 11-19 10:16 ?641次閱讀
    快速了解CAN通訊原理及應(yīng)用

    C語言中最常見的宏定義寫法

    如果讓你用C語言寫個(gè)宏定義,我相信大部分同學(xué)順手就能寫出define。
    的頭像 發(fā)表于 10-28 11:12 ?333次閱讀

    VCA8617為何內(nèi)部還有個(gè)電壓控制衰減器功能模塊?

    該芯片主要是放大信號(hào)功能,為何內(nèi)部還有個(gè)電壓控制衰減器功能模塊,很是疑惑。
    發(fā)表于 09-26 06:44

    一個(gè)人,如何管理上百個(gè)污水處理站?

    管理上百個(gè)污水處理站,無疑是項(xiàng)復(fù)雜而艱巨的任務(wù),它不僅要求管理者具備深厚的專業(yè)知識(shí)、卓越的組織協(xié)調(diào)能力,還依賴于先進(jìn)的技術(shù)支持與科學(xué)的管理模式。以下幾點(diǎn)策略,可為高效管理眾多污水處理站提供參考框架
    的頭像 發(fā)表于 09-11 17:47 ?283次閱讀
    <b class='flag-5'>一個(gè)人</b>,如何管理上百<b class='flag-5'>個(gè)</b>污水處理站?

    OPA2350做的帶通濾波器,為何輸出端輸出的波形中低電平有1.4v左右這么高?

    OPA2350做的帶通濾波器,為何輸出端輸出的波形中低電平有1.4v左右這么高?這不像軌到軌的特點(diǎn)吧。電源是3.3v的,請(qǐng)各位專家?guī)蛶兔?,產(chǎn)品近期就要發(fā)貨,急死了!
    發(fā)表于 08-29 07:04

    光電二極管輸入的偏置電流為何這么大?

    用的是光電二極管模型,輸入的偏置電流為何這么大,是固定的,但放大倍數(shù)如何求
    發(fā)表于 08-16 06:21

    OPA2626為何在高頻處,出現(xiàn)了個(gè)2db的上升?

    我在讀opa2626的手冊(cè)的時(shí)候,看官方給的圖標(biāo)發(fā)現(xiàn)個(gè)問題,就是圖1和圖3,應(yīng)該給的是不同增益下閉環(huán)電路的頻率響應(yīng)(同向或者反向電路)就像畫圈的位置,為何在高頻處,出現(xiàn)了
    發(fā)表于 08-06 07:48

    STM32F0xx_HAL_Driver庫的串口接收數(shù)據(jù)個(gè)數(shù),是不是只能寫成1,一個(gè)一個(gè)數(shù)據(jù)接收?

    ,uint8_t *pData, uint16_tSize, uint32_tTimeout ) 函數(shù)的第三個(gè)參數(shù)是接收數(shù)據(jù)的個(gè)數(shù)。 問題是: 如果不知道接收數(shù)據(jù)的個(gè)數(shù),那么是不是只能寫成1,一個(gè)一個(gè)數(shù)據(jù)接收? 這樣的話不是會(huì)影
    發(fā)表于 05-14 06:39

    容量王者,超級(jí)電容容量為何這么大?

    容量王者,超級(jí)電容容量為何這么大?“充電30秒,行駛5公里”的超級(jí)電容公交車,你坐過嗎?超級(jí)電容公交車,不難理解,它的動(dòng)力來源是超級(jí)電容。電容是常見的電路元器件之,多用于濾波、去耦等。但現(xiàn)在電容
    的頭像 發(fā)表于 03-22 09:59 ?482次閱讀
    容量王者,超級(jí)電容容量<b class='flag-5'>為何</b><b class='flag-5'>這么</b>大?

    如何寫出時(shí)序最優(yōu)的HDL代碼?如何寫出時(shí)序裕量足夠的代碼?

    你想寫出可以跑出700M以上的代碼嗎,直逼FPGA內(nèi)部PLL的極限。
    的頭像 發(fā)表于 03-12 09:59 ?945次閱讀
    如何<b class='flag-5'>寫出</b>時(shí)序最優(yōu)的HDL代碼?如何<b class='flag-5'>寫出</b>時(shí)序裕量足夠的代碼?

    串聯(lián)的總線舵機(jī)是不是只用個(gè)UART接口就能控制呢?

    串聯(lián)的總線舵機(jī)是不是只用個(gè)UART接口就能控制呢
    發(fā)表于 03-07 06:30

    梯云物聯(lián):電梯遠(yuǎn)程監(jiān)控系統(tǒng)對(duì)物業(yè)單位有哪些意義?

    電梯作為高樓載客、貨的主要工具,在未來的使用將會(huì)越來越廣泛,它是最普通的公共場(chǎng)所,所以在電梯中安裝遠(yuǎn)程監(jiān)控系統(tǒng)很有必要。因?yàn)殡娞蓐P(guān)系這每一個(gè)人的安全出行,所以電梯安全無小事,個(gè)完善的
    的頭像 發(fā)表于 03-01 18:10 ?1009次閱讀
    梯云物聯(lián):電梯遠(yuǎn)程監(jiān)控<b class='flag-5'>系統(tǒng)</b>對(duì)物業(yè)單位有哪些意義?

    為何tc397的MAC系統(tǒng)時(shí)間寄存器誤差這么大?

    外部晶振20M,用tc397作為授時(shí)master在1pps(周期1s進(jìn)次)中斷中授時(shí)模塊讀取MAC系統(tǒng)時(shí)間寄存器,連續(xù)兩次間隔理論上是1整秒,但是實(shí)際上與整秒差400多us,讀取的寄存器如下,哪位大神知道為何397的MAC
    發(fā)表于 01-22 07:38