搜尋
首頁web前端js教程Express作者TJ告別Node.js奔向Go_node.js

首先這是一篇翻譯自TJ 的Farewell Node.js  ,我自己在看完這這篇文章之後確實是受到了一些衝擊,但我並不認同作者的某些看法,比如我認為Node. js 的package register 是其許多優點之一,反而Go 在這方面卻略顯匱乏。 由於個人層級所限,在翻譯的時候有許多不懂的地方,我也去作者博客、stackoverflow 上問了一些問題,獲得了解答。翻譯仍有許多不到位的地方,希望能獲得指出意見。

PS.  身為一位Node.js 的入門菜鳥,感謝TJ 的付出,一路走好。

正文:

告別Node.js

離開Node.js領域

我一直與Node.js在生產中一起戰鬥了足夠久的時間,很不幸的是,既然我已經不再喜歡從事這份工作,至少在此刻,這是我的正式告別。更重要的是,我需要維護者。

        Node在某些方面確實很棒,但對於最近我有興趣的軟體類型,它終究不是適合的工具。我仍然打算用Node做網站,但如果你對維護任何項目感興趣,只需要留言寫下你的Github 用戶名 ,  npm 用戶名,以及項目名稱來讓我知道。通常我所要求的只有你不徹底的改變已有的api,如果真要這麼做的話,還是重新開一個新專案的好。

         Koa  是我會繼續去維護的項目。 (與Co 還有朋友們一塊)

聖杯的故事

我一直深愛著C,但每一個從事C開發工作的人都知道它是有價值卻又易於出錯的。很難在日常工作中證明語言的選擇,因為它不完全是最快的工作。簡潔也是一直讚美它的原因,但是沒有大量的模板你不會走得很遠。

隨著越多的參與分散式系統的開發,Node效能高過可用性與健壯性的發展趨勢讓我越發沮喪。在過去的一個星期中,我已經用Go重寫了一個相對大型的分佈式系統,它的健壯性、性能更好,並且易於維護,由於同步代碼普遍的更加優美並且更易於開發,它有著更好的可測試覆蓋範圍。

        我並不是說Go是聖杯,它並不完美,但對於現今存在的多種語言來說,Go於我是一個極好的答案。隨著越來越多的這些"次世代"語言如 Rust 和 Julia 找到他們自己的位置並成熟起來,我確定我們會有更多的偉大的解決方案。

        個人而言我對Go語言感到很興奮是因為他的迭代速度,很激動的看到他們渴望去達到2.0版本,並且據我所聽到的消息,他們並不害怕與打破原有的偉大事物。如果是真的話我很樂意,更多是因為我相信如果真的是有益於這門語言的,就應該快速的打破已有事物。但我也不是運行了大量系統的軟體巨人。 :D

        編著: 一定是我錯誤解讀了一些提交的郵件列表,他們在任何時候都並不渴望於做出一些破壞性的改變。 @enneff

為什麼是Go?

如果Node對你有效並且你沒有什麼需要擔心的,它仍然是一個很好的工具。但如果有些事情困擾著你,別忘了跳出你的盒子去看看在盒子外面有什麼其他的--在最初的使用Go來構建產品的幾個小時內,我已經被吸引住了。

再次聲明,我並不是在那裡說Go絕對是最好的語言而且你必須去使用它。但對於它所處年紀來說,是非常成熟而健壯的。 (大致上與Node相同年紀的時候)。類型的重構是有趣而簡單的,Go所提供的作業和調試工具是很棒的,同時社群具有非常強大的關於文件、格式​​、基準以及api設計方面的條例。

        在如此習慣於極度模組化的Node 和體驗過 Ruby 腐爛的標準庫的同時,當我第一次聽到 Go,我認為它的標準庫是糟糕的。在我深入這門語言之後,我意識到現階段極大部分的標準函式庫都是必要的,像是compression、json、IO、buffered IO、字串操作等等。大部分的這些APIS 都被定義的很好而且很強大。很容易僅僅透過使用這些標準庫來書寫整個程式。

第三者Go packages

大部分的Go 函式庫看起來都很相似,我到目前為止所使用過的大部分的第三方程式碼都是高品質的,而在Node中很難去找到這些因為JavaScript 吸引了不同技巧層次範圍內的開發者。

        對Go 的packages 來說,沒有註冊中心,所以通常會同時看到5或6種相同的包。在有些時候,這會造成一定的困惑,但它卻有一個有趣的副作用,你必須透過認真的審查每個包來決定哪一個是最佳方案。透過Node 通常有規範的套件如 "redis","mongodb-native" 或"zeromq",所以你會停在那裡就推斷出他們是最好的一個。

        如果你正在做一些分散式的工作,你會發現Go的令人印象深刻的同時基礎資料類型是非常有幫助的。我們可以透過在Node 中的generators 來獲得相似的東西,但在我看來,generators 只是做到一半而已。沒有獨立的錯誤處理、報告棧即使最好仍然是平凡的。當這些方案都能良好運作的時,我也不想等待社區三年去重整。

 在我看來,Go的錯誤處理是出眾的。就你必須考慮每一個錯誤並且決定怎麼做而言,Node是偉大的。然而Node 失敗在:

你或許會重複的進行回調

你或許根本不會進行回調 迷失在不穩定狀態中 (譯註 例如忘記傳遞錯誤處理回調,錯誤時,Node 將吞掉這個錯誤而不會有任何反饋)

你或許會得到外帶的錯誤

emitters 或許會獲得多個錯誤的事件

忘記錯誤的事件的處理會毀掉一切

常常不確定什麼需要錯誤的處理

錯誤的處理是非常冗餘的

回呼爛透了
在Go語言中,當我的程式碼結束的時候,它就結束了,你不能在語句中重新執行。在Node中這是不確定的。你會認為一個程式完全的執行完畢,直到一個函式庫意外的多次呼叫一個回調,或者沒有正確的清除handlers 然後引起程式碼的再次執行。在實際的生產代碼中要找到這些原因是相當困難的,為什麼要煩惱這些?其他語言不會讓你經歷這些痛苦。

未來的Node

我仍然希望Node 做得很好,許多的人對他進行巨額的投資,它確實有這樣的潛質。我認為Joyent 和團隊需要專注在可用性——如果你的應用程式很脆弱且很困難去調試、重構以及開發,效能是無意義的。

        在4-5年內我們仍然將有著這種模糊不清的錯誤 "Error: getaddrinfo EADDRINFO”,這個事實告訴我們Node 的發展優先順序在哪裡。可理解的是,當你專注於建立系統核心的時候,會很容易漏掉這些東西。單我認為使用者已經對這類事物一次又一次的表達了意見卻沒看到任何的結果。對於聲稱說我們擁有的東西已經是完美的,我們通常會獲得少數的回應。在實踐中,卻並非如此。

       streams 是中斷的, 回調不容易使用,錯誤含糊不清,工具並不好用,社區條例是有,相對於Go而言卻顯得匱乏。儘管如此,一些特定的任務我仍可能繼續去使用Node,例如建立網頁,或是一些零散的API或原型。如果Node可以修復一些它的基本問題,那麼它有機會保持相關性,但當存在另一個方案是更高的性能和更高的可用性的時候性能高於可用性的論證不會走的太遠。

 如果Node社群決定去擁抱generators 並能在Node 非常核心的地方實現他們,去適當的傳遞錯誤,是有機會讓這個是可參照的。這會徹底的提高Node 的可用性以及健全性。

 好消息是,不久之前我跟在 StrongLoop  裡面的貢獻核心代碼的了不起並充滿天賦的傢伙聊過。他們正在明確的採用透過傾聽開發者對這個平台的回复,並且計劃找到修復這些問題去修復的正確方式來讓未來的Node更加易於工作。我不確定多家公司對核心部分同時開發的衝突會如何結束,但我希望開發者驅動方會勝出。

        這並不代表這是一個對個人的攻擊,而許多真的有天賦的人們正在與Node或在Node之上工作,但這再也不是我感興趣的地方了。我在Node社群中經歷了一段偉大時光的同時也遇到了一些真的很有趣的人。

        故事的寓意在於,不要被自己的圈子所限制住!看看其他地方有什麼,你也許會再次享受程式設計。在這之外還有很多了不起的解決方案,我犯的錯在於等了太久才去跟他們一起遊戲!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

node.js流帶打字稿node.js流帶打字稿Apr 30, 2025 am 08:22 AM

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

Python vs. JavaScript:性能和效率注意事項Python vs. JavaScript:性能和效率注意事項Apr 30, 2025 am 12:08 AM

Python和JavaScript在性能和效率方面的差異主要體現在:1)Python作為解釋型語言,運行速度較慢,但開發效率高,適合快速原型開發;2)JavaScript在瀏覽器中受限於單線程,但在Node.js中可利用多線程和異步I/O提升性能,兩者在實際項目中各有優勢。

JavaScript的起源:探索其實施語言JavaScript的起源:探索其實施語言Apr 29, 2025 am 12:51 AM

JavaScript起源於1995年,由布蘭登·艾克創造,實現語言為C語言。 1.C語言為JavaScript提供了高性能和系統級編程能力。 2.JavaScript的內存管理和性能優化依賴於C語言。 3.C語言的跨平台特性幫助JavaScript在不同操作系統上高效運行。

幕後:什麼語言能力JavaScript?幕後:什麼語言能力JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能