yarn對比npm的優點
根據官方文檔yarn具有6大優點
離線模式
yarn會有一個緩存目錄,會緩存以前安裝過的軟件包,再次安裝時就不必從網絡下載了,大大加速安裝速度。
這一點很重要,npm 飽受詬病的一點就是,每次安裝依賴,都需要從網絡下載一大堆東西,而且是全部重新下載,工程多的時候比較煩人。
我司部署node項目,是需要在發布機上install所有的依賴而且發布機的網絡環境不是很好(不給搭梯子),導致安裝慢不說還經常失敗(部分包需要聯網編譯)。更換yarn后只需將yarn的cache目錄緩存起來,每次install嗷嗷的快,麻麻再也不用擔心發布失敗了。
依賴關系確定性
在每一台機器上針對同一個工程安裝依賴時,生成的依賴關系順序和版本是一致的。
之前 npm 在這里有一個處理得不好的地方 。舉例來說,我寫的工程依賴 A, B, C 三個庫,我在編寫 package.json 的時候,給 A, B, C 都指定了版本號。但是 A 庫可能又依賴 D, E, F 庫,D 庫又依賴 G, H 庫。這么多關聯依賴關系中,很可能某個庫在指定依賴時,沒有指定版本號。
於是,這就導致了一個問題。如果我在另一台機器上對同樣的工程安裝依賴,或者把這台機器工程下的 node_modules 目錄刪除來重新安裝依賴。由於關聯依賴中,沒有指定版本號的庫,發生了版本更新,就會導致再次安裝的依賴,其中具體某些軟件包的版本是不一致的。在這種情況下,你會發現原來能夠正常運行的程序,忽然變得不能工作或一堆 BUG.
npm對包引入順序也十分的敏感,比如在一個空項目里執行以下命令
1
2
3
4
|
npm init -y
npm install globule@
0.1.0 -S
npm install babel-generator@
6.19.0 -S
npm install babel-helper-define-map@
6.18.0 -S
|
我們這里安裝了3個包都依賴於lodash,不過globule依賴lodash@1.0.3,另外兩個依賴lodash@4.x。現在目錄依賴結構如下
這時假設我們在項目里使用lodash,但是忘記重新安裝lodash
1
2
|
var lodash = require('lodash');
console.log(lodash.VERSION); // v1.0.3
|
另一個同事獲取項目代碼,執行npm install
,這時的目錄依賴結構為
可以看到第一層依賴的lodash變成了4.x版本,這樣就造成了依賴版本不一致的問題。而yarn則會保證無論怎樣引入的順序,目錄依賴結構都是一致的,確保不會發生這樣的BUG。
網絡性能優化
下載軟件時會優化請求順序,避免請求瀑布
發生
網絡回彈
yarn在某個安裝包請求失敗時不會導致安裝失敗,它會自動去嘗試重新安裝。而npm則會毫不猶豫的失敗,導致得再來一次,耗費時間
多注冊來源
所有的依賴包,不管他被不同的庫間接關聯引用多少次,安裝這個包時,只會從一個注冊來源去裝,要么是 npm 要么是 bower, 防止出現混亂不一致。
扁平模式
對於多個包依賴同一個子包的情況,yarn會盡量提取為同一個包,防止出現多處副本,浪費空間。比如1.2中,yarn會為babel-generator和babel-helper-define-map 創建同一個lodash子依賴,這樣就節約一份的空間。
更多的emojis
正確的安裝姿勢
注意yarn依賴node運行環境,官網提供了不同環境下的N種安裝方法,點我查看。其中最重要的也是最通用的當然是npm install yarn -g
,也不知道官網搞那么多幺蛾子的安裝方式干嘛又是brew又是yum,還折騰半天。
yarn常用命令介紹
創建項目
命令yarn init
,詳細介紹
跟npm一樣,會出現一個交互式的窗口,問一些package相關的問題
1
2
3
4
5
6
7
8
9
|
question name (testdir): my-awesome-package
question version (1.0.0):
question description: The best package you will ever find.
question entry point (index.js):
question git repository: https://github.com/yarnpkg/example-yarn-package
question author: Yarn Contributor
question license (MIT):
success Saved package.json
✨ Done in 87.70s.
|
當然可以加參數 --yes/-y
來自動回答所有的問題(yes),便捷的生成一個package.json
管理依賴
注意,以下的命令都會自動更新你的package.json和yarn.lock文件
添加依賴
命令yarn add [package]@[version/tag]
,詳細介紹
這會自動把包添加到package.json里的dependencies,也同時會更新yarn.lock
1
2
3
4
5
6
|
{
"name": "my-package",
"dependencies": {
+
"package-1": "^1.0.0"
}
}
|
添加到不同的dependencies需要加如下參數
yarn add --dev/-D
添加到devDependenciesyarn add --peer/-P
添加到peerDependenciesyarn add --optional/-O
添加到optionalDependencies
更新依賴
命令yarn upgrade [package]@[version/tag]
,詳細介紹
更新某個依賴的版本,並自動更新package.json和yarn.lock文件
1
2
3
4
5
6
7
|
{
"name": "my-package",
"dependencies": {
-
"package-1": "^1.0.0"
+
"package-1": "^2.0.0"
}
}
|
刪除依賴
命令yarn remove [package]
刪除某個依賴,並自動更新package.json和yarn.lock文件
安裝依賴
命令 yarn install
,詳細介紹
會從package.json里提取所有的依賴並安裝,然后生成yarn.lock鎖定所有的依賴版本,別人執行yarn install
時會根據yarn.lock安裝依賴,保證不同的電腦安裝的依賴目錄結構完全一致。
可選參數
yarn install --flat
有且僅有一個依賴的版本被允許,多依賴會出現一個交互式窗口,讓使用者選擇某一個版本安裝yarn install --force
強制重新下載所有的依賴包yarn install --production
只下載dependencies下的依賴
全局命令
在yarn命令前加一個global修飾,可以將命令變為全局的,支持的命令有 add,bin,ls,remove,upgrade
例如npm install gulp -g
,可以用yarn global add gulp
來替代
個人使用心得
- 更換安裝源,使用阿里提供的npm register加速,
yarn config set registry 'https://registry.npm.taobao.org'
,當然如果npm已經配置過,yarn就無需再配置了。 - yarn還有許多小問題,不過官方也在努力修復中,建議時不時使用
yarn self-update
來更新版本