中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

npm的lock機制解析

發布時間:2020-09-24 22:46:02 來源:腳本之家 閱讀:239 作者:公眾號_前端搬運小工 欄目:web開發

npm是什么

npm是一個包管理工具,開源作者可以把開源包發布在平臺上供其他人下載使用。前端的同學基本都使用過npm,這里就不做過多介紹。日常工作中npm的主要用途就是根據項目的package.json使用npm install去安裝依賴。

npm install可以說是我們使用最頻繁的一個指令。在npm5版本之前,npm install會根據package.json指定的依賴版本去進行安裝。但往往package.json中指定的是一個版本范圍,例如:

"dependencies": {
  "packageA": "^2.0.0"
},

以上這個 ^2.0.0 指定的范圍是版本號大于等于2.0.0且大版本號為2。即2.6.10這個是符合的,而3.0.0和1.0.0這種是不符合的。
這樣的范圍指定會導致一個問題:A新建了一個項目,生成了上面這份package.json文件,但A安裝依賴的時間比較早,此時packageA的最新版本是2.1.0,該版本與代碼兼容,沒有出現bug。后來B克隆了A的項目,在安裝依賴時packageA的最新版本是2.2.0,那么根據語義npm會去安裝2.2.0的版本,但2.2.0版本的API可能發生了改動,導致代碼出現bug。

這就是package.json會帶來的問題,同一份package.json在不同的時間和環境下安裝會產生不同的結果。

理論上這個問題是不應該出現的,因為npm作為開源世界的一部分,也遵循一個發布原則:相同大版本號下的新版本應該兼容舊版本。即2.1.0升級到2.2.0時API不應該發生變化。

但很多開源庫的開發者并沒有嚴格遵守這個發布原則,導致了上面的這個問題。

lock機制

一個新的事物的誕生都是為了解決一個歷史問題

基于這種狀況,npm5推出了lock機制。在使用npm5.0.0之后的版本時,npm install后會自動生成package-lock.json文件,該文件記錄了當前這次install所安裝的依賴版本號。

例如當package.json的依賴如下:

"dependencies": {
  "vue": "^2.0.0"
 },

install后自動生成的package-lock.json會指定安裝vue2.6.10版本(當前最新)

"dependencies": {
  "vue": {
   "version": "2.6.10",
   "resolved": "https://registry.npm.taobao.org/vue/download/vue-2.6.10.tgz",
   "integrity": "sha1-pysaQqTYKnIepDjRtr9V5mGVxjc="
  }
 }

package-lock.json相當于本次install的一個快照,它不僅記錄了package.json指明的直接依賴的版本,也記錄了間接依賴的版本。

如果我們想在不同環境和不同時間下每次install時安裝相同版本的依賴,我們就可以把package-lock.json帶上。

當package.json和package-lock.json同時存在時,npm install會去檢測package-lock.json指定的依賴版本是否在package.json指定的范圍內。如果在,則安裝package-lock.json指定的版本。如果不在,則忽略package-lock.json,并且用安裝的新版本號覆蓋package-lock.json。

舉個例子:

// package.json
"dependencies": {
  "vue": "^2.0.0"
 }

// package-lock.json
"dependencies": {
  "vue": {
   "version": "2.1.0",
   "resolved": "https://registry.npm.taobao.org/vue/download/vue-2.1.0.tgz",
   "integrity": "sha1-KTuj76rKhGqmvL+sRc+FJMxZfj0="
  }
 }

這種情況下package-lock.json指定的2.1.0在^2.0.0指定的范圍內,npm install會安裝vue2.1.0版本。

// package.json
"dependencies": {
  "vue": "^2.2.0"
 }

// package-lock.json
"dependencies": {
  "vue": {
   "version": "2.1.0",
   "resolved": "https://registry.npm.taobao.org/vue/download/vue-2.1.0.tgz",
   "integrity": "sha1-KTuj76rKhGqmvL+sRc+FJMxZfj0="
  }
 }

這種情況下package-lock.json指定的2.1.0不在^2.2.0指定的范圍內,npm install會按照^2.2.0的規則去安裝最新的2.6.10版本,并且將package-lock.json的版本更新為2.6.10。

值得注意的是npm5一發布時并不是采取這種install邏輯,在npm5.0到npm5.6之間install的邏輯發生了多次變更,而在npm5.6之后一直沿用當前這種邏輯。

npm ci

npm5之后的lock機制滿足了要求鎖版本的開發者們的需要,我們只需要拿到一份package-lock.json就可以知道要安裝的依賴的具體版本號。但細心的同學會發現當package-lock.json指定的版本號不在package.json指定的范圍內時,package-lock.json就會被更新覆蓋。這可不利于我們去維持版本的固定。

因此后續npm也推出了npm ci的指令來解決這一問題,npm ci和npm i的不同之處在于:當package-lock.json指定的依賴版本不在package.json指定的依賴版本范圍內時,npm會報錯并取消安裝。

npm的lock機制解析

這樣我們就不怕在package-lock和package.json不一致時發生覆蓋更新。

總結

在npm5.6以后我們就可以放心大膽地使用package-lock.json文件來鎖版本,而在構建部署時可以使用npm ci安裝命令來防止npm install的覆蓋更新問題。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长春市| 大石桥市| 宕昌县| 万安县| 潜江市| 壤塘县| 庆阳市| 武夷山市| 虎林市| 吴旗县| 碌曲县| 延川县| 丹棱县| 津市市| 大丰市| 达拉特旗| 双城市| 平果县| 铁力市| 龙川县| 紫云| 鄄城县| 大埔县| 石屏县| 延庆县| 海门市| 乳山市| 长垣县| 蕲春县| 尚志市| 积石山| 东至县| 通化县| 浮山县| 景谷| 绥阳县| 江安县| 宜黄县| 景德镇市| 五大连池市| 鄂州市|