精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

關于包管理器Npm、Yarn和Pnpm的一些總結

開發 前端
對于存儲大量依賴的情況,pnpm提供了「pnpm store prune」命令,可以定期清理不再使用的依賴項,釋放磁盤空間。

寫在前面

在Node.js生態系統中,包管理器是至關重要的組件之一,它們負責維護各種應用程序和庫之間的依賴關系。npm是Node.js的默認包管理器,它的初始版本是npm1,但是它很快就被npm2所取代。

npm2

關于npm2最初作為包管理管理,采用的是node_modules嵌套模式,即每個包都會有自己獨立的node_modules,且會將各自依賴進行安裝,依賴的依賴也會產生自己的node_modules,這樣就產生了“嵌套依賴”。

就像回調嵌套一樣,容易陷入回調地獄,嵌套依賴也不例外。

這種嵌套依賴的模式,雖然可以使依賴項的版本更加明確和穩定,但是在實際應用中也存在一些問題。其中最大的問題是包的嵌套層級很深,這可能會導致安裝和更新依賴項的時間變長,并增加包的大小。此外,由于每個包都有自己的node_modules文件夾,這可能會導致文件系統中出現大量重復的依賴項,從而占用更多的磁盤空間。

在實際操作中,當需要在特定的Node.js版本中使用npm2時,可以使用Node Version Manager (nvm)來管理多個Node.js版本。例如,在切換到Node.js v4.0版本時,對應的npm版本是npm2.x。

圖片

為了更好地說明嵌套依賴的問題,我們可以通過安裝koa來演示。koa是一個基于Node.js的Web應用程序框架,它有許多依賴項,我們可以使用以下命令來安裝koa:

npm install koa

在安裝koa時,npm會自動下載和安裝所有必需的依賴項,并將它們安裝到koa的node_modules文件夾中。如果我們檢查koa的node_modules文件夾,我們會發現它包含了大量的依賴項,這些依賴項中又包含了更多的依賴項,導致整個文件夾的嵌套層級變得很深。

圖片

對于多包之間會存在公共依賴,如果對于每個依賴都生成自己獨立的node_modules,那么就會對相同包重復安裝多次,這就會占據很大的磁盤空間。且無限嵌套,也會超過windows的最大文件路徑長度限制(265個字符)。

嵌套依賴項的模式是npm2中的一個特性,雖然可以保證依賴項的版本穩定性和精確性,但是它可能會導致嵌套層級變得很深,并占用大量的磁盤空間。

yarn

我們想到,既然樹形結構存在弊端,為什么不將依賴包在根node_modules進行扁平化處理,這不就解決了依賴嵌套、依賴重復和路徑限制問題了?

此時新方式yarn就橫空誕生。

當使用yarn進行依賴管理時,我們可以看到所有依賴都會被安裝在根目錄下的node_modules文件夾中。與npm2不同的是,yarn采用了扁平依賴項的模式,這意味著相同的依賴包只會被安裝一次,并且不會存在多個嵌套的node_modules文件夾。

使用yarn add koa進行安裝,可以看到通過yarn進行管理的依賴全部平鋪在根node_modules下,且沒有重復依賴安裝的問題。

圖片

但是,當某些依賴包存在多個版本時,yarn會將其中一個版本提升到根node_modules文件夾中,而其他依賴包則會繼續維護自己的版本。這可能會導致某些依賴包無法正常工作,因為它們可能需要使用特定版本的依賴包。為了解決這個問題,yarn仍然需要使用嵌套的node_modules文件夾,以確保每個依賴包使用正確的版本。

圖片

值得注意的是,yarn采用的扁平依賴項模式具有許多優點,例如更快的安裝速度,更少的磁盤空間占用和更少的依賴沖突問題。此外,yarn還提供了一個lock文件,該文件記錄了所有依賴項的確切版本和位置,以確保依賴項的版本穩定性和一致性。

yarn的變與不變:

yarn采用了更加高效和可靠的依賴項管理方式,可以有效地避免依賴沖突和嵌套的問題。但是,對于某些多版本依賴包,yarn仍然需要使用node_modules嵌套的方式來確保每個依賴包都使用正確的版本。

npm3

npm3在2015年發布時引入了一種新的依賴項安裝算法,稱為“扁平依賴項”。其主要原理是通過將所有依賴項都放置在同一個目錄下,并使用符號鏈接來實現依賴項的共享。

在npm3中,所有依賴項都被直接安裝到根目錄下的node_modules中,而不是像npm2一樣在每個依賴包中嵌套一個node_modules目錄。這種扁平化的結構可以減少依賴項的嵌套層級,從而降低了磁盤空間的占用和文件路徑的長度。在這種模式下,所有依賴項都被安裝到頂級node_modules文件夾中,這樣就避免了嵌套依賴項的問題。這種模式雖然簡單,但是它可能會導致依賴項的版本不穩定,從而可能會導致依賴沖突的問題。

當我們使用npm3安裝koa包時,它會首先檢查該包所需的所有依賴項是否已經安裝,如果沒有安裝,則會將這些依賴項直接安裝到根目錄下的node_modules目錄中。同時,npm3會使用符號鏈接將這些依賴項鏈接到需要使用它們的包的node_modules目錄下。

圖片

通過使用符號鏈接,npm3可以實現依賴項的共享,從而避免了依賴項的重復安裝和占用大量的磁盤空間。此外,npm3還支持npm shrinkwrap命令,可以生成一個lockfile文件,記錄每個包所使用的依賴項的精確版本號,從而避免了版本沖突和不兼容的問題。

shrinkwrap 文件的作用是什么?

這個文件用于記錄整個依賴樹的結構和依賴包的版本信息,可以保證依賴包的版本穩定性和一致性。

那么使用扁平化方案就能完美解決以上問題嗎?當然不是。

  • 幽靈依賴:在聲明中沒有使用dependencies中的依賴,代碼中也可以進行reqiure引入。沒有在項目中進行顯式依賴,如果別的包不再依賴這個包,就會導致代碼因為依賴這個包,而沒有進行安裝,最終不能正常運行。
  • 磁盤浪費:對于依賴包只會提升一個,存在多個版本時其余包同樣得進行拷貝到各自node_modules下,依然會存在磁盤空間浪費。

什么是幽靈依賴?

在安裝和使用某個第三方包時,該包依賴的其他依賴沒有在它的js文件中顯式引入的情況。這些依賴可能在代碼中被引用,但是沒有被包含在軟件包的package.json文件中。這種情況被稱為“幽靈依賴”。

舉個例子,假設有個項目需要依賴包 A 和 B,而這兩個包都依賴于包 C,但是包 A 依賴于包 C 的版本 1.0.0,而包 B 依賴于包 C 的版本 2.0.0。在 npm2 中,這兩個版本的包 C 會被分別安裝在 A 和 B 的 node_modules 目錄下,不會產生沖突。但在 npm3 中,這兩個版本的包 C 可能會被安裝在同一個 node_modules 目錄下,這時候就會產生沖突,導致代碼無法運行。

圖片

雖然在npm3提供了 npm dedupe 命令,可以是手動輸入命令將重復的依賴項合并到頂層 node_modules 目錄下,避免了幽靈依賴的問題。但是好像并沒有很智能。

總的來說,npm3通過采用扁平化的依賴管理結構和符號鏈接機制,引入 shrinkwrap 文件實現了依賴項的共享和版本精確控制,并且減少了依賴項的嵌套層級和磁盤空間占用。可以手動使用 dedupe 命令等方式,解決了 npm2 中出現的幽靈依賴問題,提高了包管理的效率和可靠性。

pnpm

針對上面遺留下的兩個問題,pnpm橫空出世,采用硬鏈接和符號鏈接來管理依賴項,以減少重復下載和占用空間,從而有效地解決幽靈依賴和磁盤浪費的問題。

  • 基于內容尋址的文件系統來存儲磁盤的文件
  • 不會重復安裝同一個包,只在磁盤中寫入一次,而后在使用的地方通過hardlink
  • 同包不同版本,也盡可能復用代碼

link:也就是軟硬連接,這是操作系統提供的機制。

  • 硬連接就是同一個文件的不同引用
  • 軟鏈接是新建一個文件,文件內容指向另一個路徑

具體來說,當使用 pnpm 安裝koa包的依賴項時,它會首先檢查系統上是否已經安裝了所需的依賴項。如果已經安裝,則 pnpm 將創建一個符號鏈接到該依賴項,而不是在當前項目中復制該依賴項。這樣就避免了重復下載和占用磁盤空間的問題。

我們在命令行輸入:

pnpm add koa

圖片

圖片

此外,pnpm 還支持不同的包引用方式,如路徑引用和 git 倉庫引用,這使得 pnpm 可以更快地安裝依賴項并減少重復下載,從而提高開發效率和依賴項管理的可靠性。通過將包從全局 store 進行硬鏈接到項目的虛擬 store 中,pnpm 可以避免多次拷貝文件和深度嵌套路徑過長的問題,從而進一步減少磁盤空間的占用和提高性能。

圖片

PNPM 的核心思想是在整個項目內共享依賴項,而不是每個項目都擁有自己的依賴項副本。

這是官方文檔提供的原理圖:

圖片

可以看到有個公共的依賴包安裝池,然后通過軟鏈接引入到各個項目所需要的依賴中,這樣就減少了幽靈依賴、依賴嵌套和重復下載的問題。

PNPM的優點如下:

節省磁盤空間:pnpm采用鏈接的方式將依賴項共享到全局store中,避免了每個項目都需要拷貝一份依賴包的問題,從而顯著減少了磁盤占用空間。

提升安裝速度:pnpm不需要每次都下載相同的依賴項,而是從全局store中直接鏈接到各個項目中,因此可以極大地提高安裝速度。

避免了幽靈依賴、重復依賴和依賴嵌套:pnpm采用鏈接的方式,避免了項目之間依賴相同包不一致的問題,同時避免了重復安裝相同版本的依賴項和依賴嵌套的問題。

支持多種包引用方式:pnpm支持路徑引用和git倉庫引用,可以更加靈活地管理依賴項。

天生支持monorepo管理:得益于pnpm的軟鏈接特性,可以在同一個workspace下共享依賴和模塊等。

另外,對于存儲大量依賴的情況,pnpm提供了「pnpm store prune」命令,可以定期清理不再使用的依賴項,釋放磁盤空間。

參考文章

  • 關于現代包管理器的深度思考——為什么現在我更推薦 pnpm 而不是 npm/yarn?
  • pnpm 是憑什么對 npm 和 yarn 降維打擊的
  • 現代前端工程為什么越來越離不開 Monorepo?
  • 現代前端工程為什么越來越離不開 Monorepo?
  • 為什么越來越多的項目選擇 Monorepo?
  • pnpm官方文檔

寫在最后

最后對不同包管理器的優缺點、特點做了一些總結:

圖片

學而知不足,水平有限,還望諸君多多指教。覺得文章不錯的讀者,不妨點個關注,收藏起來上班摸魚的時候品嘗。

責任編輯:武曉燕 來源: 前端一碼平川
相關推薦

2022-02-28 10:22:08

前端管理工具

2022-02-21 09:58:31

包管理器npmyarn

2024-06-20 08:06:04

2021-02-25 07:24:35

pnpm包管理器前端

2022-05-26 08:01:44

Pnpm包管理器磁盤

2021-11-29 12:11:09

npm包管理器工具

2022-09-16 22:23:35

pnpmCLI軟件

2024-05-10 08:41:05

NPMYarn

2022-02-25 14:19:56

依賴管理前端命令

2021-11-11 11:13:20

js Npm基礎

2025-07-07 06:21:46

2020-04-10 08:50:37

Shell腳本循環

2020-05-19 14:35:42

Shell腳本循環

2020-09-28 06:45:42

故障復盤修復

2021-07-27 12:58:46

Linux包管理器安命令

2022-08-03 00:04:29

pnpmyarnnpm

2018-07-30 08:41:48

VueReact區別

2025-03-25 08:50:00

2020-12-03 12:06:54

HarmonyOS

2020-03-09 11:43:35

RustCargo編程語言
點贊
收藏

51CTO技術棧公眾號

精品国产1区2区| 国产一区二区免费在线| 日韩高清欧美高清| a级黄色一级片| 毛片免费在线观看| 日本不卡123| 久久婷婷国产麻豆91天堂 | 四虎影院观看视频在线观看| 成人国产精品免费| 国产精品久久久久久久久久久久久| 成人午夜免费影院| 久久男人av| 欧美日韩中文国产| 日本中文字幕亚洲| av在线之家电影网站| 国产精品一级二级三级| 国产91精品不卡视频| 九九精品视频免费| 久久99精品久久久久久园产越南| 91精品欧美综合在线观看最新| 国产人妻777人伦精品hd| 在线观看二区| 91捆绑美女网站| 999视频在线免费观看| 日韩在线视频不卡| 亚洲性感美女99在线| 日韩在线精品视频| 日韩中文字幕电影| 9999久久久久| 91精品国产综合久久久久久久 | 一级黄色片日本| 亚洲8888| 亚洲精品wwwww| 欧美精品色视频| 国产精品99久久久久久董美香 | 国产毛片毛片毛片毛片| 性久久久久久| 国内揄拍国内精品| 欧美人与禽zozzo禽性配| 99国产精品一区二区| 亚洲色图综合久久| 受虐m奴xxx在线观看| 成人性生交大片免费看96| 欧美私人免费视频| 男人的天堂日韩| 欧美18av| 欧美在线啊v一区| 日韩在线xxx| 涩涩网在线视频| 欧美日韩另类在线| 日本福利视频在线| 人在线成免费视频| 天天综合天天综合色| 你懂的av在线| 天堂√8在线中文| 高跟丝袜一区二区三区| 黄页网站大全在线观看| 国产自产自拍视频在线观看| 亚洲国产精品久久久久秋霞影院 | 性高湖久久久久久久久| 欧美一级视频一区二区| 丁香六月婷婷综合| 欧美亚洲免费| 国产福利视频一区二区| 久久久精品毛片| 免费观看在线综合色| 国产精品夜色7777狼人| 一本色道久久综合亚洲| 激情欧美一区二区| 亚洲aⅴ男人的天堂在线观看| 999av视频| 国产v日产∨综合v精品视频| 产国精品偷在线| 天天操天天干天天操| 久久午夜羞羞影院免费观看| 日日噜噜噜噜夜夜爽亚洲精品| 高清国产福利在线观看| 国产精品成人一区二区艾草| 91精品国产吴梦梦| 97在线超碰| 91久久奴性调教| 91丨九色丨蝌蚪| 国产成人澳门| 国产视频丨精品|在线观看| 日韩一区二区a片免费观看| 色爱综合网欧美| 欧美精品中文字幕一区| aaa人片在线| 免播放器亚洲一区| 亚洲综合自拍一区| 香蕉视频成人在线| 国产精品丝袜久久久久久app| 中文字幕欧美日韩一区二区三区| 久草成色在线| 在线免费视频一区二区| 激情在线观看视频| 欧美人妖在线观看| 日韩视频免费中文字幕| 成年人午夜视频| 日av在线不卡| 国产成人成网站在线播放青青| 日韩偷拍自拍| 亚洲精品乱码久久久久久黑人| 欧美大片在线播放| 国产成人免费av一区二区午夜 | 成人精品在线视频| 天天干天天干天天干| 国产精品久久久久久久久快鸭| 日本黄色片一级片| h1515四虎成人| 亚洲第一精品福利| 手机av免费看| 欧美日本精品| 国产精品视频地址| 欧美理论在线观看| 亚洲高清免费在线| 欧美激情第3页| 尤物tv在线精品| 欧美激情va永久在线播放| 日本成人一级片| 成人精品视频一区二区三区| 在线丝袜欧美日韩制服| 婷婷综合六月| 日韩的一区二区| 欧美日韩激情在线观看| 蜜桃av噜噜一区| 久久66热这里只有精品| 美女精品导航| 91精品国产一区二区三区| xxxx日本免费| 国产日韩欧美一区| 国产传媒一区二区| 成年人黄视频在线观看| 欧美日韩和欧美的一区二区| 久久久久久久久久久国产精品| 亚洲无线一线二线三线区别av| 成人黄色短视频在线观看| 国产女人在线观看| 色呦呦网站一区| 五月开心播播网| 激情欧美一区| 99热最新在线| 欧美韩日亚洲| 精品美女一区二区三区| 性欧美疯狂猛交69hd| 老司机免费视频一区二区| 日本不卡二区高清三区| 激情都市亚洲| 亚洲性视频网站| 91porny九色| 国产网站一区二区三区| 亚洲欧美另类动漫| 日产午夜精品一线二线三线| 97av在线视频| 色av男人的天堂免费在线| 欧美日韩精品在线视频| 波多野结衣av在线观看| 天堂va蜜桃一区二区三区| 欧美乱偷一区二区三区在线| 美脚恋feet久草欧美| 亚洲天堂男人天堂| 中文字幕乱码在线观看| 中文字幕一区免费在线观看| 91av视频免费观看| 欧美福利在线| 国产精品亚洲不卡a| av中文字幕电影在线看| 日韩电影中文字幕| 久久久蜜桃一区二区| 中文字幕av资源一区| av在线网址导航| 欧美久久99| 精品国产一区二区三区麻豆免费观看完整版| 国产一二三在线| 国产一区二区三区直播精品电影| 伊人精品在线视频| 亚洲视频免费在线观看| 日韩久久久久久久久久久| 亚洲第一伊人| 日本一区网站| 亚洲欧美在线综合| 欧美激情精品久久久久久久变态| 人人妻人人玩人人澡人人爽| 色综合天天综合网天天看片| 肉色超薄丝袜脚交69xx图片| 国产激情视频一区二区在线观看| 人妻无码久久一区二区三区免费| 猛男gaygay欧美视频| 91精品久久久久久久久久久久久久| 伊人222成人综合网| 日韩精品视频三区| 91丨porny丨在线中文| 亚洲va欧美va人人爽午夜 | 国产一卡不卡| 亚洲影院高清在线| 成人性生交大片免费观看网站| 最新国产精品亚洲| 特黄视频在线观看| 欧美日本一区二区在线观看| 久久久全国免费视频| 国产日产欧美一区二区三区| 国产麻豆剧传媒精品国产| 蜜桃伊人久久| 乱熟女高潮一区二区在线| 少妇精品久久久| 超碰97人人在线| 国产精品亚洲成在人线| 国语自产精品视频在线看抢先版图片 | 欧美成人精品1314www| 久久久久久无码精品大片| 亚洲一区av在线| 来吧亚洲综合网| 337p粉嫩大胆噜噜噜噜噜91av| 久久久九九九热| 秋霞电影一区二区| 国产欧美在线一区| 黄色工厂这里只有精品| 亚洲乱码国产乱码精品天美传媒| 欧美丝袜美腿| 999热视频| 国产亚洲精彩久久| 日本中文字幕久久看| 蜜乳av一区| 麻豆成人在线看| av资源网站在线观看| 亚洲美女视频网站| 蜜桃视频久久一区免费观看入口| 7777精品伊人久久久大香线蕉完整版 | 国产亚洲自拍偷拍| 精品国产亚洲一区二区三区大结局 | 在线观看日韩专区| 欧美日韩伦理片| 日韩的一区二区| 天天色棕合合合合合合合| 日韩欧美激情在线| av一区二区三| 在线观看91av| 亚洲视频在线免费播放| 在线视频观看一区| 波多野结衣不卡| 日本韩国欧美一区| 亚洲欧美综合自拍| 欧美午夜久久久| 日本天堂网在线| 欧美日韩视频免费播放| 久草手机在线观看| 亚洲va欧美va人人爽| 国产成人自拍视频在线| 五月天欧美精品| 97人人澡人人爽人人模亚洲 | 这里只有精品视频| av在线播放网站| 在线观看日韩av| 欧美成年黄网站色视频| 日韩一区二区精品视频| 精品国产99久久久久久| 免费不卡欧美自拍视频| 欧美日韩经典丝袜| 国内精品久久久久伊人av | 欧美日韩国产一区二区| 国语对白永久免费| 色8久久人人97超碰香蕉987| 久草热在线观看| 欧美日韩精品欧美日韩精品一综合| 一二区在线观看| 91麻豆精品国产91久久久 | 亚洲午夜在线观看| 91成人国产| 农民人伦一区二区三区| 销魂美女一区二区三区视频在线| www.涩涩涩| 国产乱码字幕精品高清av | 久操国产精品| 一卡二卡3卡四卡高清精品视频| 五月婷婷亚洲| 国产真人做爰毛片视频直播| 亚洲一区二区三区免费在线观看| 免费看a级黄色片| 国产一区二区三区免费播放 | av一级亚洲| 久久国产精品-国产精品| 精品一区二区三区的国产在线观看| 亚洲欧美日产图| 欧美性色综合| 任你操这里只有精品| 精品一区二区三区蜜桃| 扒开伸进免费视频| 中文子幕无线码一区tr| 亚洲国产成人精品综合99| 欧美性xxxx极品hd满灌| 国产精品特级毛片一区二区三区| 亚洲成人av中文字幕| 幼a在线观看| 97av在线视频| 免费一区二区三区在线视频| 久久青青草原| 亚洲区综合中文字幕日日| 久久精品国产精品亚洲色婷婷| 久久99国产精品成人| 五十路六十路七十路熟婆| 成人欧美一区二区三区| 欧美三级午夜理伦| 日韩三级电影网址| a视频网址在线观看| 91精品国产777在线观看| 成人短视频软件网站大全app| 免费一区二区三区| 欧美福利在线| 四季av一区二区三区| 久久日一线二线三线suv| 美女福利视频在线观看| 欧美午夜精品一区二区蜜桃| 五月激情六月婷婷| 欧美成人精品激情在线观看| 欧美123区| 蜜桃欧美视频| 亚洲大黄网站| 红桃视频一区二区三区免费| 国产午夜精品美女毛片视频| 色播视频在线播放| 欧美一卡二卡三卡四卡| 在线免费观看黄色av| 欧美中文字幕视频| 久久黄色影视| 国产精品一色哟哟| 国产精品自拍毛片| 永久免费观看片现看| 91久久精品一区二区| 婷婷视频在线观看| 久久久久久尹人网香蕉| 日韩中文字幕在线一区 | 亚洲人www| 日本人妻一区二区三区| 亚洲私人影院在线观看| 在线观看黄色网| 一区二区三区四区视频| 国产精品一区二区av影院萌芽| 国精产品一区二区| 亚洲欧洲一区二区天堂久久| yjizz视频| 五月天中文字幕一区二区| 免费国产羞羞网站视频| 欧美激情视频免费观看| 一区二区在线视频观看| 男人添女人下部视频免费| 国产成人精品三级麻豆| 亚洲国产成人精品综合99| 日韩欧美一二三| 免费影视亚洲| 国产一区二区无遮挡| 国产亚洲精品v| 一级黄色片大全| 在线国产电影不卡| 在线观看h片| 亚洲一区二区三区四区在线播放 | 欧美高清在线播放| 亚洲高清在线一区| 国产日韩欧美精品在线观看| 成人动漫av在线| 久久亚洲精品国产| 亚洲欧美精品一区二区| 日韩另类视频| 91香蕉视频网址| 国产成人av资源| 91香蕉在线视频| 亚洲无av在线中文字幕| 国产精品xxx| 成人午夜视频免费观看| 99精品热视频| 国产精品第六页| 久久精品成人欧美大片古装| 一区二区三区视频播放| 国产资源在线视频| 国产欧美日韩不卡| 99久久久国产精品无码免费| 羞羞色国产精品| 精品成av人一区二区三区| 网站在线你懂的| 精品成人av一区| 波多野结衣在线网站| 亚洲最大av在线| 国产美女一区| 亚洲精品自拍视频在线观看| 日韩欧美一级片| 亚洲一区资源| 艳母动漫在线观看| 99久久精品国产观看| 美女黄页在线观看| 欧美国产中文字幕| 激情五月色综合国产精品| 91精品国产高清91久久久久久| 欧美性猛交xxxx富婆弯腰| 国产丰满美女做爰| 国产成人精品日本亚洲| 欧美1区2区视频| 中文字幕一区二区三区人妻不卡| 欧美一区二区视频免费观看| 不卡av影片| 毛片av在线播放| 国产欧美精品区一区二区三区|