1. 程式人生 > 其它 >yarn與npm區別

yarn與npm區別

Yarn是什麼?

“Yarn是由Facebook、Google、Exponent 和 Tilde 聯合推出了一個新的 JS 包管理工具 ,正如官方文件中寫的,Yarn 是為了彌補 npm 的一些缺陷而出現的。”這句話讓我想起了使用npm時的坑了:

  • npm install的時候巨慢。特別是新的專案拉下來要等半天,刪除node_modules,重新install的時候依舊如此。
  • 同一個專案,安裝的時候無法保持一致性。由於package.json檔案中版本號的特點,下面三個版本號在安裝的時候代表不同的含義。
  • 我來舉個栗子 =><=
  • “5.0.3”表示安裝指定的5.0.3版本,“~5.0.3”表示安裝5.0.X中最新的版本,“^5.0.3”表示安裝5.X.X中最新的版本。

  這就麻煩了,常常會出現同一個專案,有的同事是OK的,有的同事會由於安裝的版本不一致出現bug。

  • 安裝的時候,包會在同一時間下載和安裝,中途某個時候,一個包丟擲了一個錯誤,但是npm會繼續下載和安裝包。
  • 因為npm會把所有的日誌輸出到終端,有關錯誤包的錯誤資訊就會在一大堆npm列印的警告中丟失掉,並且你甚至永遠不會注意到實際發生的錯誤

帶著這些坑,我們開始瞭解Yarn的優勢及其解決的問題。

yarn介紹:

  • yarn是一種新的hadoop資源管理器,是一個通用資源管理系統,可為上層應用系統提供統一的資源管理和排程。
  • yarn的基本思想是將JobTracker的兩個主要功能資源管理和作業排程/監控分離,主要方法是建立一個全域性的ResourceManager和若干個針對應用程式的ApplicationMaster。
  • 主要優點是大大減小了 JobTracker的資源消耗,並且讓監測每一個 Job 子任務 (tasks) 狀態的程式分散式化了,更安全、更優美。

Yarn的優點?

  • 速度快 。速度快主要來自以下兩個方面:
  1. 並行安裝:無論 npm 還是 Yarn 在執行包的安裝時,都會執行一系列任務。npm 是按照佇列執行每個 package,也就是說必須要等到當前 package 安裝完成之後,才能繼續後面的安裝。而 Yarn 是同步執行所有任務,提高了效能。
  2. 離線模式:如果之前已經安裝過一個軟體包,用Yarn再次安裝時之間從快取中獲取,就不用像npm那樣再從網路下載了。
  • 安裝版本統一:為了防止拉取到不同的版本,Yarn 有一個鎖定檔案 (lock file) 記錄了被確切安裝上的模組的版本號。每次只要新增了一個模組,Yarn 就會建立(或更新)yarn.lock 這個檔案。這麼做就保證了,每一次拉取同一個專案依賴時,使用的都是一樣的模組版本。npm 其實也有辦法實現處處使用相同版本的 packages,但需要開發者執行 npm shrinkwrap 命令。這個命令將會生成一個鎖定檔案,在執行 npm install 的時候,該鎖定檔案會先被讀取,和 Yarn 讀取 yarn.lock 檔案一個道理。npm 和 Yarn 兩者的不同之處在於,Yarn 預設會生成這樣的鎖定檔案,而 npm 要通過 shrinkwrap 命令生成 npm-shrinkwrap.json 檔案,只有當這個檔案存在的時候,packages 版本資訊才會被記錄和更新。
  • 更簡潔的輸出:npm 的輸出資訊比較冗長。在執行 npm install <package> 的時候,命令列裡會不斷地打印出所有被安裝上的依賴。相比之下,Yarn 簡潔太多:預設情況下,結合了 emoji直觀且直接地打印出必要的資訊,也提供了一些命令供開發者查詢額外的安裝資訊。
  • 多註冊來源處理:所有的依賴包,不管他被不同的庫間接關聯引用多少次,安裝這個包時,只會從一個註冊來源去裝,要麼是 npm 要麼是 bower, 防止出現混亂不一致。
  • 更好的語義化: yarn改變了一些npm命令的名稱,比如 yarn add/remove,感覺上比 npm 原本的 install/uninstall 要更清晰。

Yarn和npm命令對比

npmyarn
npm install yarn
npm install react --save yarn add react
npm uninstall react --save yarn remove react
npm install react --save-dev yarn add react --dev
npm update --save yarn upgrade

yarn和npm的主要區別介紹:

  • 1. yarn雖然和nom一樣是本地快取,但是yarn無需網際網路連結就能安裝本地快取的依賴項,提供了離線模式,而這個是npm實現不了的。
  • 2. yarn解決了由於語義版本控制而導致的npm的不確定性問題,通過安裝時建立的預設檔案,確保使用的庫的版本相同。
  • 3. yarn增加了一些能讓開發人員並行化處理所有必需的操作,且通過添加了一些改進,使得執行速度有了顯著的提升,整個安裝時間也變得更少。
  • 4. npm的輸出資訊比較冗長,相比之下,yarn簡潔很多。預設情況下,直觀且直接地打印出必要的資訊。
  • 5. yarn的語義相對於npm更加清晰,主要是因為yarn改變了一些npm的命令名稱,看上去就更清晰了。

npm的未來:npm5.0

有了yarn的壓力之後,npm做了一些類似的改進。

  1. 預設新增了類似yarn.lock的 package-lock.json;
  2. git 依賴支援優化:這個特性在需要安裝大量內部專案(例如在沒有自建源的內網開發),或需要使用某些依賴的未釋出版本時很有用。在這之前可能需要使用指定 commit_id 的方式來控制版本。
  3. 檔案依賴優化:在之前的版本,如果將本地目錄作為依賴來安裝,將會把檔案目錄作為副本拷貝到 node_modules 中。而在 npm5 中,將改為使用建立 symlinks 的方式來實現(使用本地 tarball 包除外),而不再執行檔案拷貝。這將會提升安裝速度。目前yarn還不支援。

總結

在npm5.0之前,yarn的優勢特別明顯。但是在npm之後,通過以上一系列對比,我們可以看到 npm5 在速度和使用上確實有了很大提升,值得嘗試,不過還沒有超過yarn。



參考簡書原文作者:Simbawu
連結:https://www.jianshu.com/p/254794d5e741