pnpm管理依賴包如何節(jié)省磁盤空間詳解
npm 存在的問題
我們經常使用 npm
來管理 node 項目中的包,從 package.json
中讀取配置將依賴下載到本地,以保障項目的正常運行。
當項目數(shù)量多時,這樣的包管理方式會非常的占用電腦內存。由于每個項目都有屬于自己的依賴,每個項目都需要安裝,即使 npm 會對依賴進行緩存,但是每個項目仍然需要安裝到自己的 node_modules
文件夾下,此時每個項目安裝的每一份依賴都會在磁盤中保存一份,即使各個項目中依賴的版本可能相同。
pnpm
就是針對以上問題出現(xiàn)的解決方案,它使用統(tǒng)一的倉庫來存放項目中的包,在項目中使用硬鏈接+軟連接的方式找到依賴所在磁盤的位置。
硬鏈接和軟連接
想要清晰的知道 pnpm 管理依賴的原理,首先要了解硬鏈接和軟連接、拷貝操作的區(qū)別。
拷貝
操作會在磁盤中復制一份新的數(shù)據
,比如拷貝 a.js 為 a_copy.js,兩個文件在拷貝后就互不關聯(lián),修改 a.js 不會影響 a_copy.js,刪除 a_copy.js 也不會影響 a.js。
硬鏈接
是通過尋址的方式
找到磁盤中的數(shù)據,比如新建 b_hard.js 與 b.js 創(chuàng)建硬鏈接,兩者指向的是同一個磁盤數(shù)據,所以修改其中一個文件,另一個文件也會發(fā)生變化。
軟連接
就是我們平時常見的創(chuàng)建快捷方式
(文件后面會存在一個向右的小箭頭),它只是保存著文件的路徑,不可以編輯,直接雙擊就會找到原始的文件。如果原文件被刪除,通過軟連接將無法找到磁盤中的數(shù)據。
我們可以通過命令來進行連接操作,windows 是這樣的
/*拷貝*/ copy a.js a_copy.js /*硬鏈接*/ mklink /H b_hard.js b.js /*軟連接*/ mklink c_soft.js c.js
pnpm原理
使用 npm 或者 yarn 時,如果有100個項目,并且所有項目都有一個相同的依賴包,那么在磁盤上就需要保存100份該相同依賴的包
。
如果使用 pnpm,依賴包將被放在統(tǒng)一的位置,當安裝包時,其包含的所有文件會硬鏈接到這個位置,不會另外占用磁盤空間,這樣不同項目之間就可以共享相同版本的依賴。
如果對同一依賴包使用相同的版本
,那么磁盤上只有這個依賴包的一份文件,如果對同一依賴包使用不同的版本
,那么只有版本之間不同的文件
被存儲起來。
比如 a/b/c 三個項目都使用 axios,axios 的所有文件都保存在 pnpm 上,axios 這些文件對應著磁盤的數(shù)據,直接 a/b/c 項目的axios 通過硬鏈接指向磁盤里的數(shù)據。 這樣有兩個好處:
(1)效率非常高,無需下載、查找緩存解壓等操作
(2)節(jié)省磁盤空間,每個項目不需要再下載一份
pnpm 依賴包統(tǒng)一保存的位置可以使用命令 pnpm store path
來查看
非扁平的 node_modules 目錄
使用 npm 或者 yarn安裝的依賴包會將所有的子級依賴全部平鋪
到 node_modules 文件夾中,即扁平化的目錄結構,這樣會導致源碼可以訪問本來不屬于當前項目所設定的依賴包。
比如安裝 axios ,同時會安裝非常多的其它的庫如 form-data,雖然在 package.json 中是沒有配置的,但在源代碼中可以直接通過require('form-data') 引用
,這樣就會有隱患,如果項目某天刪除了 axios,form-data 就不存在了。
使用 npm 和 pnpm 分別只安裝 axios,npm 會將 axios 所需的其它依賴平鋪,而 pnpm 的 node_modules 根目錄下只有 axios 和 .pnpm 文件夾,這樣就可以避免非主動下載的其它依賴包可隨意訪問的情況。
如果直接按照這樣的層級下載包,可能會帶來新的問題,如多個包依賴同一個包時,就會被重復安裝。
? node_modules ? axios ? node_modules ? form-data ? xxx ? node_modules ? form-data
那 pnpm 是如何做到非扁平化并且不重復安裝的呢?答案就是它使用硬鏈接與軟連接結合的方式來與依賴包關聯(lián)。
在 node_modules 根目錄有一個文件夾 .pnpm,這里包含了項目所有依賴。
根目錄下 axios 軟連接
到 .pnpm 目錄下的 axios 文件夾中,展開 .pnpm/axios@16.1 的node_modules 文件夾,其中有 axios 所需的依賴,包含 axios、follow-redirects、form-data、proxy-from-env,其中 axios 硬鏈接
到磁盤中(即與 pnpm 倉庫保存的地址一致),其它文件軟連接到 .pnpm 的自身位置。
node_modules 根目錄下的依賴
,軟連接到 .pnpm 文件夾中,如果有相互依賴的關系,仍然通過軟連接,只有找到依賴自身,才會通過硬鏈接找到磁盤中的位置,這樣可以保證同一個項目里不同依賴也不會重復安裝,同時不同項目之間的相同依賴也無需在磁盤中存儲多份。
以上就是pnpm管理依賴包如何節(jié)省磁盤空間詳解的詳細內容,更多關于pnpm依賴包磁盤空間的資料請關注腳本之家其它相關文章!
相關文章
node.js使用stream模塊實現(xiàn)自定義流示例
這篇文章主要介紹了node.js使用stream模塊實現(xiàn)自定義流,結合實例形式詳細分析了node.js基于stream模塊實現(xiàn)自定義的可讀流、可寫流、可讀寫流等相關操作技巧,需要的朋友可以參考下2020-02-02用node擼一個監(jiān)測復聯(lián)4開售短信提醒的實現(xiàn)代碼
這篇文章主要介紹了用node擼一個監(jiān)測復聯(lián)4開售短信提醒的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04如何用nodejs給C#寫一個數(shù)據表的實體類生成工具
這篇文章主要介紹了如何用nodejs給C#寫一個數(shù)據表的實體類生成工具,對nodejs感興趣的同學,可以參考下2021-05-05