2021-02-22 分類: 網(wǎng)站建設(shè)
近日,Linus Torvalds 與 VMware 首席開源官 Dirk Hohndel 關(guān)于 Linux 內(nèi)核維護(hù)未來的討論引起了技術(shù)圈的關(guān)注。Linus 認(rèn)為,在他們這批 Linux 內(nèi)核維護(hù)者老去之后,很難再找到新的繼任者,因?yàn)樵诤芏嗄贻p開發(fā)者看來 “ Linux 內(nèi)核項(xiàng)目并不那么有趣 ”。
在與 Dirk 的談話中,Linus 認(rèn)為 Linux 內(nèi)核開發(fā)對大多數(shù)人來說是無聊的。“ 我說過內(nèi)核很無聊,但我的意思是從某種意義上說,許多新技術(shù)應(yīng)該比內(nèi)核開發(fā)更有趣。但是對我和其他內(nèi)核開發(fā)者來說,沒有什么能夠比與底層硬件交互的內(nèi)核開發(fā)更有趣的了,因?yàn)檫@能真正控制所有將在計算機(jī)中發(fā)生的事情。所以內(nèi)核對我來說并不是很無聊,但是我想大多數(shù)人應(yīng)該會認(rèn)為它們很無聊。”
該談話很快就轉(zhuǎn)到了一個令人不安的問題上:既然現(xiàn)在對于內(nèi)核開發(fā)感興趣的人越來越少,那么當(dāng) Linux 內(nèi)核在當(dāng)前一代的維護(hù)者老去之后,社區(qū)的未來該怎么辦?
目前,Linux 內(nèi)核維護(hù)者主要還是即將年滿 51 歲的 Linus 和一些 50 或 60 后的老程序員?!?在某個時候,Linux 社區(qū)需要開始考慮交接變革,屆時我們該怎么辦?” Dirk 問。
對此 Linus 本人倒是頗為樂觀,他認(rèn)為目前整個 Linux 內(nèi)核社區(qū)其實(shí)還不算老。“很多新人還不到 50 歲,他們通常是從事真正工作(給項(xiàng)目貢獻(xiàn)代碼)的人。而那些已經(jīng)在社區(qū)里近三十年的老人,比如我和一些早期的項(xiàng)目參與者,我們的主要精力已經(jīng)放在了項(xiàng)目的維護(hù)和管理上?!?/p>
“我們確實(shí)有不少編寫代碼的人,但缺少維護(hù)者。” 在 Linus 看來,Linux 內(nèi)核項(xiàng)目未來交接的難點(diǎn)在于尋找一個自己的繼任者。“ 事實(shí)證明,我們現(xiàn)在很難找到合格的新維護(hù)者。因?yàn)槌蔀閮?nèi)核維護(hù)者,你必須一直存在,這意味著你每天都要在電腦前閱讀來自全球各地的電子郵件,對郵件做出反應(yīng),就像我這 30 年來做的一樣,從不間斷。我們現(xiàn)在很難找到真正看待他人代碼,并在上游嚴(yán)格把關(guān)每一個提交,判斷它們能否合并到我們的主干代碼上的人。這是我們面臨的最主要的問題?!?Linus 說。
還有一個問題是維護(hù)者必須花費(fèi)很長的時間才能獲得整個社區(qū)的信任。Linus 說:“這不僅是其他維護(hù)者的信任,也是所有代碼貢獻(xiàn)者的信任……這需要時間。30 年前,當(dāng)我們剛開始做這個項(xiàng)目時,我們其實(shí)并不需要什么信任。只要你出現(xiàn)在社區(qū)里,就能參與進(jìn)來,我們一起把這個東西做好。但現(xiàn)在有很多人依賴著 Linux 內(nèi)核,你不能像我們曾經(jīng)那樣做一些瘋狂的事情。”
作為一個在世界范圍內(nèi)舉足輕重的開源項(xiàng)目,Linux 內(nèi)核項(xiàng)目正面臨著開發(fā)者老齡化、維護(hù)者難尋的局面。而針對這次討論,國外的一些開發(fā)者也在論壇上表達(dá)了自己的看法。很多人認(rèn)為,造成這一局面在一定程度上歸咎于 Linus 與外界溝通的態(tài)度。
“維護(hù)者難尋?提這問題是認(rèn)真的嗎,我想不會有人愿意收到這樣的答復(fù) —— ‘這也算是一個 BUG?你已經(jīng)成為內(nèi)核維護(hù)者多長時間了?還沒有學(xué)會內(nèi)核維護(hù)的第一條規(guī)則?我再也不想收到這種明顯的垃圾,像白癡一樣的提交…… ’ —— 當(dāng)時看到這樣的回復(fù)真的讓我很震驚?!?一位網(wǎng)友引用了此前 Linus 在郵件列表中公開的一段回復(fù),指出 Linus 在人際溝通中的惡劣態(tài)度是很多人對這項(xiàng)工作望而卻步的關(guān)鍵因素。
跟帖的網(wǎng)友認(rèn)為,在一段正常的工作關(guān)系中,上級領(lǐng)導(dǎo)對員工的支持往往比責(zé)備更有利于項(xiàng)目的進(jìn)展?!拔页姓J(rèn) Linus 至今為止所取得的一切成就,但如果有人按照上述的溝通方式與我的團(tuán)隊(duì)溝通,那我一定會糾正這個人的態(tài)度再開始工作。盡管 Linus 有著比絕大多數(shù)老板都聰明的大腦,但他的態(tài)度和那些狗屎老板一樣的爛?!?更何況 Linus 還不是任何人的領(lǐng)導(dǎo),沒有人愿意被一個從未見過面的人劈頭蓋臉地公開數(shù)落。
也有理性的開發(fā)者表示,盡管 Linus 的嘴巴 “很笨拙”,但不可否認(rèn)要做好這項(xiàng)工作真的很難。這名開發(fā)者認(rèn)為 Linux 內(nèi)核項(xiàng)目目前存在的問題是學(xué)習(xí)門檻太高,缺乏曲線平滑的學(xué)習(xí)資料?!?雖然我同意大多數(shù)人會因?yàn)楹ε孪窆肥阂粯颖?Linus 拒之門外,但這對于我們中一些臉皮比較厚的人來說,這其實(shí)倒也無所謂。我自己作為一個年齡比較大的技術(shù)人員,我可以理解 Linus 的憤怒來自何處,他需要保護(hù)成千上萬的 Linux 用戶;也能理解為什么年輕的技術(shù)人員可能將其視為純粹的侵略性。我喜歡能夠在內(nèi)核級別進(jìn)行開發(fā),但是相關(guān)的學(xué)習(xí)資源卻是稀缺且通常難以理解的。我已經(jīng)用各種不同的語言編寫了 20 多年的代碼,但現(xiàn)在我仍然不知道 Linux 內(nèi)核開發(fā)該從哪里開始才能對項(xiàng)目做出有用的貢獻(xiàn)。”
建立由淺及深、完善的學(xué)習(xí)文檔和示例是一個項(xiàng)目吸引新人才加入所必需的,Linux 內(nèi)核項(xiàng)目也是如此。但是以 Linux 內(nèi)核項(xiàng)目如今的體量,要做出一份好的文檔將是一個非常艱難的工作。一位已經(jīng)退休的開發(fā)者認(rèn)為,如今的 Linux 內(nèi)核項(xiàng)目的上手難度和幾十年前相比已經(jīng)呈指數(shù)倍增長。“ 當(dāng)我退休時,我為我的項(xiàng)目留下了詳細(xì)的文檔和示例偽代碼,據(jù)我估計,這些代碼,文檔和示例偽代碼將使開發(fā)團(tuán)隊(duì)足足工作 8 個月才能完全接手項(xiàng)目。顯然,Linux 內(nèi)核的文檔和示例代碼帶來的工作量將遠(yuǎn)超這一數(shù)字。而我剛開始編程那會,在占用 2kW 以下功率的 16 位微處理器上處理機(jī)器代碼程序,我可以理解最少的文檔并了解整個過程。但現(xiàn)在,考慮在程序中使用 C 語言進(jìn)行極其復(fù)雜的處理并帶有各種引用和與其他事物的關(guān)系協(xié)同工作,我甚至完全不知道該從哪里開始思考。對一個新人開發(fā)者來說,要完全掌握 Linux 內(nèi)核的全貌是一個巨大的、艱難的過程?!?/p>
也就是說,Linux 內(nèi)核項(xiàng)目要吸引更多年輕開發(fā)者的加入,所需要解決的問題已經(jīng)不僅僅是文檔,管理一切事務(wù)的組織機(jī)構(gòu)是必須的?!皢栴}必須是 Linus 是否創(chuàng)建了一個自我維持和管理的成熟體系來將整個事情整合在一起?!?由淺及深的教程資料,年輕人才的招募等等,這些工作將需要社區(qū)里具有出色的組織和人際交往能力的人才能實(shí)現(xiàn),而不是光靠代碼可以解決的問題。
很難想象,當(dāng) Linus 這批程序員老去時,Linux 將走向何方?
網(wǎng)頁名稱:Linux 內(nèi)核維護(hù)者難尋:“我不想被 Linus 噴”
本文路徑:http://www.rwnh.cn/news9/102409.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、軟件開發(fā)、網(wǎng)站營銷、全網(wǎng)營銷推廣、靜態(tài)網(wǎng)站、品牌網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容