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

剖析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技術棧公眾號

成人午夜大片免费观看| 日韩中文理论片| 懂色av一区二区| 久久久久久久久久久久久久久| 91精品1区2区| 91九色在线porn| 日韩影视精品| 亚洲伊人色欲综合网| 精品国产一二三区| 9色porny| 六十路在线观看| 久久99精品视频| 欧美激情亚洲激情| 69xxx免费视频| 厕沟全景美女厕沟精品| 国产精品久久久久久久久免费桃花| 国产精品啪视频| 中国毛片直接看| 超碰97久久| 日本乱人伦一区| 久久视频免费在线| 日本国产在线观看| 久久福利资源站| 欧美激情区在线播放| av网站免费在线看| 免费一区二区三区在线视频| 精品福利免费观看| 亚洲日本欧美在线| 手机看片福利在线观看| 久久精品国内一区二区三区| 久久成人一区二区| 丝袜美腿中文字幕| 国产精品日本一区二区不卡视频 | 日本亚洲欧美在线| 精品无人区麻豆乱码久久久| 欧美日韩性生活| 国产av国片精品| 国产成人午夜| 国产亚洲1区2区3区| 超碰97人人在线| 中文字幕 日韩有码| 亚洲欧洲日本mm| 国产一区二区三区三区在线观看| 337p日本欧洲亚洲大胆张筱雨| 日韩大片欧美大片| 亚洲国产另类av| 日本高清xxxx| 在线视频二区| 久久久美女艺术照精彩视频福利播放| 91视频国产高清| 最新黄色网址在线观看| 久久久精品日韩| 国内精品一区二区三区| 日本一二三区在线观看| 欧美一级精品| 亚洲少妇中文在线| 中文字幕在线观看的网站| 欧美亚洲人成在线| 欧美在线免费观看视频| 少妇高潮喷水在线观看| 国产精品—色呦呦| 亚洲图片自拍偷拍| 日韩欧美亚洲在线| 亚洲欧美日韩综合在线| 国产成人精品免费在线| 91香蕉亚洲精品| 国产乱淫a∨片免费观看| 蜜桃在线一区二区三区| 国产精品白嫩美女在线观看| 麻豆久久久久久久久久| 在线观看的日韩av| 97涩涩爰在线观看亚洲| 国产午夜在线播放| 国产欧美精品久久| 69视频在线播放| 国产亚洲精品久久777777| 午夜国产欧美理论在线播放| 久久亚洲精品中文字幕冲田杏梨| 中文字幕一二三四区| 色婷婷久久久| 亚洲欧美制服另类日韩| 国产美女永久免费无遮挡| 欧美视频免费| xvideos成人免费中文版| 三级影片在线观看| 色综合天天综合网中文字幕| 久久精品亚洲国产| 欧美日韩黄色网| 黄页网站一区| 欧美裸身视频免费观看| 国产麻豆a毛片| 俺要去色综合狠狠| xvideos成人免费中文版| 久久精品亚洲a| 午夜精品影院| 8050国产精品久久久久久| 亚洲自拍一区在线观看| 蜜桃免费网站一区二区三区| 91中文在线观看| 亚洲国产999| 成人免费毛片app| 久久国产精品亚洲va麻豆| 亚洲aⅴ在线观看| 国产喷白浆一区二区三区| 亚洲欧洲日夜超级视频| 国产在线69| 精品久久久香蕉免费精品视频| 无码日韩人妻精品久久蜜桃| 国产精品亚洲综合在线观看| 亚洲激情视频在线播放| 青娱乐国产视频| 欧美日韩一区二区三区四区在线观看| 韩日精品中文字幕| 夜夜爽8888| 91小视频在线观看| 欧美日韩精品一区| 成人福利网站| 精品久久久精品| 中文字幕1234区| 日韩欧美黄色| 亚洲新中文字幕| 国产精品夜夜夜爽阿娇| 亚洲黄色在线| 国产在线日韩在线| 外国精品视频在线观看 | 国产 日韩 欧美 综合| 99re66热这里只有精品3直播| 亚洲精品无人区| av3级在线| 欧美精品在线一区二区| 人妻少妇精品视频一区二区三区| 日韩欧美精品一区| 97久久精品视频| 国产亲伦免费视频播放| 国产亚洲女人久久久久毛片| 成年人三级视频| 播放一区二区| 亚洲第一在线视频| 黄视频网站免费看| 日本不卡一区二区| 免费中文日韩| 免费av不卡在线观看| 欧美日韩成人高清| 无码一区二区三区在线| 亚洲美洲欧洲综合国产一区| 国产精品99久久久久久白浆小说 | 国产精品一区二区久久精品爱涩| 欧美另类视频在线| 国产精选在线| 欧美大肚乱孕交hd孕妇| 三级影片在线观看| 日本中文在线一区| 蜜桃日韩视频| 在线中文字幕播放| 日韩大陆毛片av| 久草资源在线视频| 日日噜噜夜夜狠狠视频欧美人| 国产精品免费一区二区三区在线观看| 成人免费在线电影| 色成人在线视频| 国产三级视频网站| 日韩一级在线| 久久66热这里只有精品| 国产高潮在线| 日韩成人网免费视频| 青青操免费在线视频| 成人性视频网站| 国产黄色激情视频| 成人av影音| 久久久国产影院| 97成人在线观看| 亚洲欧美另类图片小说| 国产人妻精品久久久久野外| 中文字幕亚洲精品乱码| 成人写真视频福利网| 免费黄色在线网站| 91精品欧美一区二区三区综合在 | 亚洲图中文字幕| 亚洲综合图片网| 91色综合久久久久婷婷| 国产精品免费入口| 欧美日韩久久精品| 成人av在线网址| 青草在线视频| 亚洲第一天堂无码专区| 免费看毛片网站| 欧美高清在线一区二区| wwwwwxxxx日本| 欧美色一级片| 免费观看国产成人| 国产成人精选| 欧美精品免费在线观看| 高h放荡受浪受bl| 色综合久久九月婷婷色综合| 人妻在线日韩免费视频| 久久99在线观看| 日韩激情视频一区二区| 亚洲区小说区图片区qvod按摩| 国产精品丝袜白浆摸在线 | 欧美jizz18| 欧美日韩国产123| 日韩精品一二| 在线不卡a资源高清| 国产一级生活片| 日本一区二区三区国色天香 | 日韩欧美成人免费视频| av资源在线免费观看| 韩国av一区二区三区四区| 东北少妇不带套对白| 亚洲ab电影| 成人福利网站在线观看| 亚洲国产精品精华素| 亚洲精品xxxx| 国产精品久久欧美久久一区| 亚洲成a人片在线不卡一二三区| 久久精品—区二区三区舞蹈| 国产精品中文字幕欧美| 97超碰人人爱| 久久不卡国产精品一区二区| 日本精品久久久| 污片视频在线免费观看| 国产亚洲精品久久久| 丰满人妻一区二区| 欧美日产国产精品| 色网站在线播放| 亚洲日本韩国一区| 美女久久久久久久久久| 久久91精品国产91久久小草| 日本精品久久久久中文字幕| 欧美片第1页综合| 亚洲国产另类久久久精品极度| 国产在线播放精品| 国产精品丝袜高跟| 黑人巨大精品欧美一区二区桃花岛| 不用播放器成人网| 高清av在线| 亚洲欧美日韩国产中文| 国产精品系列视频| 欧洲av一区二区嗯嗯嗯啊| 日韩欧美高清在线观看| 亚洲欧美国产三级| 青青青视频在线免费观看| 久久免费电影网| 2025中文字幕| 国产精品综合视频| 男生操女生视频在线观看| 日韩不卡免费视频| 999在线观看视频| 免费一区二区| 欧美美乳视频网站在线观看| 露出调教综合另类| 国产麻豆日韩| 影音先锋欧美激情| 999国产视频| 国产激情久久| 国产精品美女无圣光视频| 亚洲美女炮图| 18久久久久久| 末成年女av片一区二区下载| 国内精品久久久久久中文字幕| 色www永久免费视频首页在线| 久久九九国产精品怡红院| 国产三级在线观看| 国产亚洲在线播放| 9色在线视频| 日韩一区二区三区xxxx| 熟妇高潮一区二区高潮| 亚洲国产一区自拍| 香蕉视频免费在线看| 日韩风俗一区 二区| 成人h动漫精品一区二区无码 | 99热精品免费| 亚洲免费av高清| 精品99久久久久成人网站免费| 一区二区在线免费| 欧美日韩国产精品综合| 亚洲欧美视频在线观看视频| 国产 日韩 欧美 成人| 精品久久久久久久久久久| 国产第一页在线播放| 亚洲免费色视频| 麻豆天美蜜桃91| 亚洲成av人片一区二区三区| 国产精品美女久久久久av爽| 一本色道久久综合亚洲aⅴ蜜桃| 免费观看成人毛片| 色94色欧美sute亚洲线路一ni| 中文字幕一区二区三区免费看| 欧美精品乱人伦久久久久久| 不卡的日韩av| 亚洲精品自拍视频| 午夜毛片在线| 久久精品视频网站| 国产伦久视频在线观看| 国产99久久精品一区二区永久免费| 亚洲十八**毛片| 国产日产亚洲精品| 久久a爱视频| 国产一区自拍视频| 久草在线成人| 三上悠亚免费在线观看| 在线观看一区视频| 国产视频一区二区三区在线播放 | 松下纱荣子在线观看| 国产精品久久不能| 日韩精品成人在线观看| 久久综合九色99| 91成人观看| 国产精品333| 精品午夜一区二区三区在线观看 | 2021年精品国产福利在线| 蜜桃臀一区二区三区| 亚洲精品国产首次亮相| 亚洲视频综合在线| 日韩福利影院| 综合日韩在线| 日本免费观看网站| 狠狠久久亚洲欧美| 欧美高清精品一区二区| 国产成人精品综合在线观看| 性欧美精品中出| 洋洋成人永久网站入口| 成人免费一级片| 亚洲第一视频网| 黄色成人在线| 欧美一区二区三区免费观看| 无遮挡爽大片在线观看视频| 成人性生交大片免费看视频直播| 日韩精品丝袜美腿| 97超碰人人爱| 蜜桃av一区二区| 日韩精品在线视频观看| 久久99精品久久久久久久青青日本 | 欧美激情亚洲国产| 国产精品无码av在线播放| 99久久精品免费看国产交换| 久久精品福利| 亚洲欧美日本韩国| 国产97在线|日韩| 日韩aaaaa| 久久男人天堂| 国产传媒欧美日韩成人| 中文字幕一区日韩电影| 又色又爽又高潮免费视频国产| 欧美性猛交bbbbb精品| 国模大尺度视频一区二区| 国产一区二区按摩在线观看| www.亚洲男人天堂| 国产在线视频在线| 中文字幕永久在线观看| 成人影院中文字幕| 亚洲va天堂va国产va久| 国产男女在线观看| 成人不卡视频| 国产噜噜噜噜久久久久久久久| 国内视频在线精品| 久久av高潮av| 秋霞国产午夜精品免费视频| 国产成人精品无码片区在线| 亚洲视频一区在线观看| 91影院在线播放| 久久久av网站| 日本国产欧美| 亚欧精品在线| 久久精品二区亚洲w码| 战狼4完整免费观看在线播放版| 亚洲女与黑人做爰| 波多野结衣在线观看一区| 亚洲美女性视频| 色偷偷偷在线视频播放| 欧美精品一区二区三区在线四季 | 中文日韩电影网站| 中文字幕第36页| 午夜av在线播放| 成人在线视频首页| 国产91精品青草社区| 黄色av免费播放| 国产精品极品| 欧美日韩国产美| 欧美男女爱爱视频| 高h视频在线观看| 成人av网站在线观看| 国内精久久久久久久久久人| 成人免费av片| 日韩欧美另类中文字幕| 欧美日韩国产专区| 国产成人三级视频| 日本中文字幕电影在线免费观看| av电影在线观看完整版一区二区| 97免费视频在线| 日本一级片在线播放| 日本精品另类| 亚洲国产成人av网| 日韩精品第1页| 国产在线1区| 国产精品色婷婷| 中文字幕在线观看第三页| 国产一区网站| 久久成年人免费电影| 成人国产精品入口免费视频|