国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

剖析Npm、Yarn 與 Pnpm 依賴管理邏輯

開發 前端
我們在項目開發的過程中會引用到各種不同的庫,各種庫又依賴了其他不同的庫,這些依賴應該如何進行管理,今天這篇文章主要聊的就是這個事情。

[[437341]]

我們在項目開發的過程中會引用到各種不同的庫,各種庫又依賴了其他不同的庫,這些依賴應該如何進行管理,今天這篇文章主要聊的就是這個事情。

npm2的依賴管理npm2 安裝依賴的時候比較簡單直接,直接按照包依賴的樹形結構下載填充本地目錄結構。

比如在項目中A和 C 都依賴 B,無論被依賴的 B 是否是同一個版本,都會直接無腦的生成對應的樹結構,比如我們現在有下面的依賴:

  • A@2.0.0:BaseA@1.0.0 BaseB@2.0.0
  • B@3.0.0:BaseA@1.0.0 BaseB@2.0.1

那么npm i之后node_modules里面生成的內容將是下面這樣的

這樣的結構非常直觀,但是有一個問題就是,如果項目的依賴過多的話,可能導致下面這些問題:

  1. 生成的依賴嵌套非常深
  2. 相同版本的依賴大量冗余

npm3/yarn的依賴管理

npm3對于npm2的情況進行了優化,那么如何進行優化呢?其實我們最直觀的思路就是將樹打平,將依賴扁平化,不就能解決嵌套過深和依賴冗余的問題。所以,在上面的例子中,如果我們用npm3來進行install,最后生成的node_modules會是這樣的結構:

這樣看起來是不是就好多了,但是此時會有什么問題呢?我們實操一下試試看。在項目中安裝A和B

可以看到我們項目本身的依賴文件里面只有a_klx和b_klx,但是執行完npm i命令后卻發現多了幾個我們沒有引入的包a_base_klx和b_base_klx。

其實這是由a_klx和b_klx本身自己引入的npm包,但是卻出現在了我們的node_modules下。那么如果我們直接使用這兩個包會有什么反應呢?

可以看到,我們是可以正常使用這兩個我們并未聲明在依賴中的npm包的,因為這兩個包存在于我們項目的node_modules下,根據npm包的查找規則,我們是可以找到這兩個包的。所以這種依賴關系就導致了下面兩個問題:

  1. 我們項目本身的node_modules結構不夠直觀
  2. 依賴不安全,我們可以使用依賴文件中并沒有聲明的npm包

其實第一點的問題并不是很大,主要是第二點可能會導致一些奇怪的問題。以我們之前的例子來說,我們可以直接在項目里面直接使用a_base_klx,因為node_modules里面這兩個包實際上是存在的,但是他們又不是永遠存在的。萬一有一天,a_klx和b_klx里都去除了這兩個基礎包的引用,node_modules里面將不再存在a_base_klx和b_base_klx,那么我們的代碼就會出現問題...也就是:

我的代碼啥也沒動,放了一個晚上就壞了!

同時,我們對于這種處理方式其實很容易有一個疑問,如果我同時引用了同一個包的多個不同版本,會幫我把哪個包提出來,同時我每次npm i之后提出來的包版本都是一樣的嗎?會不會存在這次是2.0.0版本下次是2.0.1版本的情況,比如我們下面這種情況:

  • A@1.0.0:BaseA@1.0.0 BaseB@2.0.0
  • B@1.0.0:BaseA@1.0.0 BaseB@2.0.1
  • D@1.0.0:BaseA@1.0.0 BaseB@2.0.1

生成的依賴是下面這樣的:

還是下面這樣的:

其實看起來后面這個更合理,因為有兩個包用到了2.0.1版本,將它提出來更好,我們實際操作一下試試:

被提到最外層的包是2.0.0版本的,然后b_klx和d_klx的node_modules下面各自有一個 b_base_klx@2.0.1這一塊的內容自己查了一下,大部分說法是會根據package.json里面的順序決定誰會被提出來,放在前面的包依賴的內容會被先提出來。

不過自己實操了一下發現并不是這樣,即使我把b_klx或者d_klx移到最前面,被提出來的包依然是a_klx依賴的2.0.0版本,隨后自己翻了一下npm的源碼,發現內部其實會對拿到的依賴列表進行一些處理

最終會通過localeCompare方法對依賴進行一次排序,所以字典序在前面的npm包的底層依賴會被優先提出來,對于我們的例子來說就是a_klx所依賴的b_base_klx@2.0.0會被優先提出來。

pnpm的依賴管理

pnpm為了解決上述這些問題,采用了一種不同于npm/yarn的依賴管理方式。

如果我們用pnpm再來安裝一遍上面的依賴,會發現項目的node_modules文件夾只有當前package.json中所聲明的各個依賴(的軟連接),而真正的模塊文件,存在于node_modules/.pnpm,由模塊名@版本號形式的文件夾扁平化存儲(解決依賴重復安裝)。同時這樣設計,也很好的避免了之前可以訪問非法npm包的問題,因為當前項目的node_modules只有我們聲明過的依賴,這也讓node_modules里面的文件看起來非常的直觀。

同時,node_modules/.pnpm中存儲的文件其實是pnpm實際緩存文件的「硬鏈接」,從而避免了多個項目帶來多份相同文件引起的空間浪費問題。

但是說到硬鏈接,又有一個問題,這相當于所有項目都依賴了同一個文件,那么在一個項目中修改了某個npm包的文件,就會影響到其他項目,這對于postinstall是很不友好的。隨后繼續實操了一下,確實在不同項目中修改了某個npm包后會影響到其他項目。同時自己平時有時候也會直接在node_modules里面調試一些東西..感覺這種處理方式對于這種操作來說也不是很友好。

但是從pnpm的官網來看,其實它默認會使用copy-on-write 的方式來進行處理,也就是如果你嘗試對內容進行修改的話,會復制一份文件而不會影響到源文件。

然后它不生效的原因似乎是因為libuv的bug:https://github.com/pnpm/pnpm/issues/2761,所以在copy-on-write不生效的情況下被回退到了hardlink 的方式去處理。

參考文檔:

https://pnpm.io/npmrc#package-import-method

https://github.com/pnpm/pnpm/issues/2761

 

責任編輯:姜華 來源: Tecvan
相關推薦

2022-02-25 14:19:56

依賴管理前端命令

2022-02-28 10:22:08

前端管理工具

2022-09-16 22:23:35

pnpmCLI軟件

2024-06-20 08:06:04

2022-02-21 09:58:31

包管理器npmyarn

2024-05-10 08:41:05

NPMYarn

2025-03-25 08:50:00

2025-09-15 00:00:01

2025-07-07 06:21:46

2025-10-20 08:17:01

2023-04-12 00:00:40

Node.jsMonoreponpm

2022-08-03 00:04:29

pnpmyarnnpm

2024-12-04 13:54:19

pnpm存儲項目

2021-02-25 07:24:35

pnpm包管理器前端

2025-03-24 00:00:15

2025-01-21 11:18:46

2024-04-03 09:03:05

2014-01-07 15:05:25

HadoopYARN

2022-10-09 14:50:24

前端pnpm工具

2023-12-15 15:14:10

yarn任務管理資源管理
點贊
收藏

51CTO技術棧公眾號

久久精品一二三| 欧美a级在线观看| 青春草在线免费视频| 9色porny自拍视频一区二区| 精品亚洲va在线va天堂资源站| 国产精品久久波多野结衣| 三级黄色网址| 亚洲裸体俱乐部裸体舞表演av| 国外成人在线视频网站| 国产一级二级三级精品| 久久一本综合| 国产一区二区在线免费| 欧美人与牛zoz0性行为| 555www成人网| 嫩草影视亚洲| 国产精品白丝jk喷水视频一区| 国产精品任我爽爆在线播放| 久久久久久国产精品| а天堂中文最新一区二区三区| 亚洲石原莉奈一区二区在线观看| 久草在线中文最新视频| 日韩电影中文字幕在线观看| 麻豆免费在线| 亚洲视频在线观看视频| 全球最大av网站久久| 这里只有精品丝袜| 精品午夜av| 国产精品白丝久久av网站| 亚洲成人精品视频在线观看| а√天堂中文资源在线bt| 亚洲а∨天堂久久精品喷水| а√天堂中文资源在线bt| 亚洲欧美一区二区激情| 欧洲成人一区| 欧美老肥婆性猛交视频| 亚洲欧洲色图| 超碰国产精品久久国产精品99| 国产精品日本| 男人天堂成人网| 91蜜桃在线免费视频| 日本 片 成人 在线| 亚洲免费在线视频| 日本午夜在线视频| 欧美tickling挠脚心丨vk| 日韩一区二区三区在线免费观看| 欧美精品xxx| 亚洲精品a级片| 日韩国产欧美精品| 成人激情校园春色| 九色视频一区| 337p亚洲精品色噜噜狠狠| 韩国三级一区| 国产精品99久久99久久久二8| 羞羞答答成人影院www| 亚洲免费久久| 中文字幕久久午夜不卡| 免费在线视频你懂得| 亚洲精品国产精品国自产在线| 91成人入口| 国产精品免费在线播放| 国产在线视频一区二区| 香艳视频网站| 欧美不卡一区二区| 六月丁香久久丫| 欧美亚洲精品日韩| 久久精品人人做人人爽人人| 性网站在线看| 亚洲天堂网站在线观看视频| 欧美精品一二| 一区二区三区四区免费观看| 国产精品电影院| 丁香影院在线| 国产精品久久久91| 国产高清在线精品| 日本大片在线观看| 日韩在线视频免费观看高清中文| 国产精品精品国产一区二区| 日本xxx免费| 一区二区免费在线| 伊人久久av| 96pao国产成视频永久免费| 国产一区二区三区久久悠悠色av| 大地资源高清播放在线观看| 亚洲欧美精品在线| 国产精品vip| www.97| 亚洲欧美中文日韩在线v日本| 日韩毛片视频| 91日韩视频在线观看| 日韩精品中文字幕在线| 欧美 亚欧 日韩视频在线| 色多多视频在线播放| 精品性高朝久久久久久久| 亚洲乱码免费伦视频| 色综合97天天综合网| 成人性生交大片免费看中文| 同心难改在线观看| 欧美精品一区二区三区国产精品| 米奇777在线欧美播放| 在线视频尤物| 97涩涩爰在线观看亚洲| 国产精品自产自拍| 美女欧美视频在线观看免费 | 亚洲男人的天堂在线| 亚洲欧美色图| 成人羞羞视频免费看看| 色噜噜久久综合伊人一本| 视频一区欧美日韩| 国产69久久| 国产精品三级美女白浆呻吟| 国产人久久人人人人爽| 蜜桃视频成人m3u8| 亚洲一区精彩视频| 91精品国产福利| 在线欧美不卡| yw193.com尤物在线| 国产精品网红福利| 国产精品美女久久久久久| 亚洲精品毛片| 欧美 国产 综合| 日韩av在线播放资源| 日韩国产欧美在线播放| 成人免费在线| 久久亚洲高清| 5566中文字幕一区二区电影| 欧美在线不卡| 国产一区二区三区福利| 91在线观看免费观看 | 真人抽搐一进一出视频| 亚洲精品中文字幕有码专区| 国产真实乱对白精彩久久| 筱崎爱全乳无删减在线观看| 一区高清视频| 日韩大片在线观看视频| 麻豆国产精品官网| 色网在线免费观看| 亚洲乱码日产精品bd在线观看| 国产一区二区三区久久精品| 成人av免费在线观看| 久久久国产精品入口麻豆| 视频二区在线播放| 国产xxx69麻豆国语对白| 亚洲一区二区四区蜜桃| 国产一区国产二区国产三区| 69免费视频| 国产日韩在线精品av| 色网综合在线观看| 噜噜爱69成人精品| 亚洲欧美韩国| 亚洲乱码国产一区三区| 国产成人黄色av| 色综合天天狠狠| 久久久久国产精品午夜一区| 亚洲精品mv| 99re6在线视频| 亚洲一区二区三区777| 日韩午夜在线影院| 成人a区在线观看| 要久久爱电视剧全集完整观看 | 国产日韩一区欧美| 日韩免费一区二区| 国产麻豆精品在线观看| 国产区精品视频在线观看豆花| 麻豆影视在线观看| 蜜桃999成人看片在线观看| 亚洲精品视频在线播放| 2017欧美狠狠色| 一精品久久久| 手机在线观看av网站| 蜜桃免费在线视频| 高清av免费一区中文字幕| 亚洲精品视频二区| 国产精品视频线看| 亚洲国产91| 蜜桃在线一区| 免费在线黄色影片| 精品人妻大屁股白浆无码| 日韩美女激情视频| 日韩限制级电影在线观看| 久久久夜色精品亚洲| 亚洲美女视频| 四虎国产精品免费久久| 全部免费毛片在线播放网站| www亚洲国产| 国产成人亚洲综合91| 精品久久久久久久一区二区蜜臀| 久久久久国色av免费看影院| 欧美 日韩 国产 一区| 成人精品动漫| a黄色在线观看| 在线免费视频a| 欧美资源一区| 国产精品久久久久77777| 亚洲片国产一区一级在线观看| 亚洲地区一二三色| 国产成人精品www牛牛影视| 99精品视频在线观看播放| 国产综合色区在线观看| 亚洲精品承认| 免费看的毛片|