站長資訊網
        最全最豐富的資訊網站

        JavaScript包管理器比較:Npm vs Yarn vs Pnpm

        本篇文章帶大家了解一下三種JavaScript包管理器(npm、yarn、pnpm),并將這三種包管理器進行對比,聊聊npm、yarn、pnpm三者的區別和關聯,希望對大家有所幫助,如有問題歡迎指出!

        JavaScript包管理器比較:Npm vs Yarn vs Pnpm

        包管理器領域的三個主要參與者:

        • npm

        • Yarn

        • 高性能 npm (pnpm)

        實際上我們已經在所有包管理器中實現了基本相似的功能,因此您很可能會根據非功能性要求來決定使用哪個包管理器,例如安裝速度、存儲消耗或實際情況。

        當然,您選擇使用每個包管理器的方式會有所不同,但它們都有基本一致的概念。以上這些包管理器都可以執行以下指令:

        • 讀寫數據
        • 批量安裝或更新所有依賴項
        • 添加、更新和刪除依賴項
        • 運行腳本
        • 發布包

        然而盡管如此,包管理器在底層還是有所不同的。傳統上 npmYarn 將依賴項安裝在一個平鋪的node_modules文件夾中。(這里注意先后順序,是 yarn 先平鋪的,之前 npm 是遞歸)。但是平鋪也會造成一系列的安全問題。

        • 依賴結構的不確定性

        • 扁平化算法本身的復雜性很高,耗時較長。

        • 項目中仍然可以非法訪問

        • 有聲明過依賴的包

        因此,pnpmnode_modules 文件夾中引入了一些新概念來更高效的存儲依賴,。Yarn Berry 甚至通過完全放棄 node_modules 的 (PnP) 模式(另一個文章會具體說明)來走得更遠。

        JavaScript package簡史


        最早發布的包管理器是 npm,早在 2010 年 1 月。它就確立了今天包管理器工作的核心原則。但是既然 npm 已經存在 10 多年了,為什么還有其他選擇?以下是出現這種情況的一些關鍵原因:

        • node_modules 文件夾結構的依賴關系解析算法不同(嵌套 & 平鋪、node_modules vs. PnP mode)
        • 依賴提升方式不同(hoisting
        • locking 格式不同(性能都不同,比如 yarn 自己寫的那一套)
        • 磁盤存儲包文件方式不同(空間效率不同)
        • 多包項目(又名 workspaces)的支持不同,這會影響 monorepos 的可維護性和速度
        • 新工具和命令的需求不同(通過插件和社區工具對可擴展性的需求不同)
        • 可配置性和靈活性不同

        讓我們深入了解一下 npm 崛起后這些方面如何確定的歷史,Yarn Classic 如何解決其中的一些問題,pnpm如何擴展這些概念,以及 Yarn Berry 作為 Yarn Classic 的繼任者如何打破這些傳統的概念和流程。

        先驅者 npm

        npm 是包管理器的鼻祖。許多人錯誤地認為 npm 是“Node package manager”的首字母縮寫詞,但事實并非如此。

        它的發布構成了一場革命,因為在此之前,項目依賴項都是手動下載和管理的。npm 引入了諸如文件及其元數據字段、將依賴項存儲在node_modules, 自定義腳本, 公共和私有包等等。

        2020 年,GitHub 收購了 npm,所以原則上 npm 現在歸微軟管理。在撰寫本文時,最新的主要版本是 v8,于 2021 年 10 月發布。

        創新者 Yarn Classic

        在 2016 年 10 月,Facebook 宣布與 Google 和其他一些公司合作開發一個新的包管理器(engineering.fb.com/2016/10/11/…),以解決 npm 當時存在的一致性、安全性和性能問題。他們將替代品命名為Yarn。

        盡管 Yarn 還是基于 npm 的許多概念和流程來架構設計的,但 Yarn 還是對包管理器領域產生了重大影響。與 npm 相比,Yarn 并行化操作以加快安裝過程,這一直是 npm 早期版本的主要痛點。

        Yarn 為讀寫、安全性和性能設定了更高的標準,還發明了許多概念(后來npm也為此做了很多改進),包括:

        • monorepo 支持
        • 緩存安裝
        • 離線下載
        • 文件鎖(Locking

        Yarn v1 于 2020 年進入維護模式 。從那時起,v1.x 系列被認為是舊版,并更名為 Yarn Classic。它的繼任者 Yarn v2 (Berry) 現在是更加活躍的開發分支。

        更高效的pnpm

        pnpm 的第 1 版由 Zoltan Kochan于 2017 年發布。它是 npm 的替代品,所以如果你有一個 npm 項目,你可以馬上使用 pnpm

        創建 pnpm 的主要原因是 npmYarn 對于跨項目使用的依賴項存儲結構非常冗余。盡管 Yarn Classicnpm 具有速度優勢,但它使用相同的依賴解析方法,這對 pnpm 來說是不行的:npmYarn Classic 使用 hoisting 來平鋪他們的 node_modules.

        pnpm 沒有優化之前的結構,而是引入了另一種依賴解決策略:內容尋址的一種存儲結構。此方法生成的 node_modules 文件夾其實是依賴于全局存儲在主文件夾上的 ~/.pnpm-store/ 目錄。每個版本的依賴項都物理形式存儲在該目錄文件夾中一次,構成單一的源地址來節省相當多的磁盤空間。

        node_modules 結構是通過使用 symlinks 創建依賴關系的嵌套結構(其中文件夾內每個文件/包都是通過硬鏈接存儲)官方文檔中的下圖闡明了這一點。(待填坑:軟硬鏈接)

        JavaScript包管理器比較:Npm vs Yarn vs Pnpm

        2021 年報告中可見 pnpm 的影響力:因為他們在內容可尋址存儲方面的創新,競爭對手都希望采用 pnpm 的概念,比如象征性鏈接的結構和包的高效磁盤管理。

        Yarn (v2, Berry),用 Plug'n'Play 重新發明的輪子

        Yarn 2于 2020 年 1 月發布,被宣傳為原始 Yarn 的重大升級。Yarn 團隊將其稱為 Yarn Berry 以更明顯地表明它本質上是一個具有新的代碼庫和新的原則規范的新包管理器。

        Yarn Berry 的主要創新是其即插即用 (PnP)方法,它是作為修復node_modules的策略。不是生成node_modules 的策略,而是生成一個帶有依賴查找表的文件 .pnp.cjs,因為它是單個文件而不是嵌套的文件夾結構,所以可以更有效地處理依賴。此外,每個包都以zip 文件的形式存儲在文件夾內來替代 .yarn/cache/,占用的磁盤空間也比 node_modules 少。

        所有這些變化如此之快以至于在發布后引起了很大的爭議。PnP 這種破壞性的重大更改要求維護者更新他們現有的包以便與其兼容。默認情況下使用全新的 PnP 方法并且恢復到 node_modules 最初并不簡單,這導致許多知名開發人員沒有加入其中的考慮且公開批評 Yarn 2。

        此后,Yarn Berry 團隊在其后續版本中解決了許多問題。為了解決 PnP 的不兼容問題,團隊提供了方法來輕松更改默認操作模式。在node_modules插件的幫助下,切換回傳統 node_modules 方法只需要一行配置。

        此外,隨著時間的推移,JavaScript 生態系統為 PnP 提供了越來越多的支持,正如您在此兼容性表中所見,一些大型項目已經開始采用 Yarn Berry

        盡管 Yarn Berry 還很年輕,但它也已經對包管理器領域產生了影響——pnpm 在 2020 年末采用了PnP 方法。

        安裝工作流程


        首先必須在每個開發人員的本地和 CI/CD 系統上安裝包管理器。

        npm

        npmNode.js 一起提供,因此不需要額外的步驟。除了為您的操作系統下載Node.js 安裝程序外,使用 CLI 工具管理軟件版本已成為一種常見做法。在 Node 的上下文中,Node Version Manager (nvm) 或 Volta 已成為非常方便的實用程序。

        Yarn Classic 和 Yarn Berry

        您可以通過不同的方式安裝 Yarn 1,例如,作為 npm 包來安裝:.$ npm i -g yarn

        要從Yarn Classic 遷移到 Yarn Berry,推薦的方法是:

        • 安裝或更新 Yarn Classic 到最新的版本

        • 使用命令升級到最新的現代版本

          yarn set version berry

        但是,在此推薦的安裝 Yarn Berry方法是通過 Corepack。

        Corepack是由 Yarn Berry 的開發者創建的。該計劃最初被命名為包管理器管理器(pmm) ?,并在 LTS v16 中與 Node 合并。

        在 Corepack 的幫助下,因為 Node 包含 Yarn ClassicYarn Berrypnpm 二進制文件所以您不必“單獨”安裝的 npm 的替代包管理器。這些墊片允許用戶運行 Yarn 和 pnpm 命令而無需先顯式安裝它們,也不會弄亂 Node 發行版。

        Corepack 預裝了 Node.js ≥ v16.9.0。但是,對于較舊的 Node 版本,您可以使用⬇️

        npm install -g corepack

        在使用之前先啟用 Corepack。該示例顯示了如何在 Yarn Berry v3.1.1 中激活它。

        # you need to opt-in first $ corepack enable # shim installed but concrete version needs to activated $ corepack prepare yarn@3.1.1 --activate

        pnpm

        您可以將 pnpm 作為 npm包來安裝: $ npm i -g pnpm。您還可以使用 Corepack 安裝 pnpm :

        $ corepack prepare pnpm@6.24.2 --activate

        項目結構


        在本節中,您將一目了然地看到不同包管理器的主要特征。您可以輕松發現配置特定包管理器涉及哪些文件,以及哪些文件是由安裝步驟生成的。

        所有包管理器都將所有重要的元信息存儲在項目清單package.json文件中。 此外,根級別的配置文件可以被用來設置不同的私有包或者不同的依賴項解析配置。

        在安裝步驟中,依賴項 dependencies 被存儲在文件結構中,例如 node_modules 并生成鎖定文件 locking。本節不考慮工作區設置,因此所有示例僅顯示存儲依賴項的單個位置。

        npm

        使用$ npm install 或較短的 $ npm i 會生成一個 package-lock.json 文件和一個 node_modules 文件夾。還有 .npmrc 這種可配置的文件可以放在根級別目錄里面。有關 locking 文件的

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲国产精品综合久久一线 | 久久久精品久久久久久| 亚洲AV无码精品色午夜果冻不卡 | 亚洲综合精品网站| 亚洲精品无码不卡| 99国产精品无码| 无码精品国产VA在线观看| 精品无码专区亚洲| jizz国产精品| 久久久久夜夜夜精品国产| 国产精品亲子乱子伦xxxx裸| 一本之道av不卡精品| 久久久久国产精品三级网| 国产精品99无码一区二区| 日韩一级精品视频在线观看| 99国产精品久久| 精品国产福利一区二区| 日韩精品乱码AV一区二区| 亚洲欧美精品丝袜一区二区| 久久精品免费大片国产大片| 国产精品美女久久久网AV| 91精品国产高清久久久久久国产嫩草 | 精品无码久久久久久久久久| 国产精品99爱免费视频| 亚洲国产精品婷婷久久| 精品国精品国产| 国产精品亚洲午夜一区二区三区| 国产精品无码a∨精品| 国产精品偷伦视频观看免费 | 在线观看国产精品日韩av| 亚洲精品国产自在久久| 在线精品动漫一区二区无广告| 日韩精品视频在线观看免费| 四虎精品免费永久免费视频| 亚洲精品国产精品乱码不卞| 综合在线视频精品专区| 亚洲精品乱码久久久久久蜜桃不卡 | 欧美精品亚洲精品日韩传电影| 日韩精品一区二区亚洲AV观看| 亚洲国产另类久久久精品黑人| 亚洲精品制服丝袜四区|