欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

npm的lock機(jī)制解析

 更新時間:2019年06月20日 09:05:06   作者:公眾號_前端搬運(yùn)小工  
這篇文章主要介紹了npm的lock機(jī)制解析,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

npm是什么

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

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

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

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

這就是package.json會帶來的問題,同一份package.json在不同的時間和環(huán)境下安裝會產(chǎn)生不同的結(jié)果。

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

但很多開源庫的開發(fā)者并沒有嚴(yán)格遵守這個發(fā)布原則,導(dǎo)致了上面的這個問題。

lock機(jī)制

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

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

例如當(dāng)package.json的依賴如下:

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

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

"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相當(dāng)于本次install的一個快照,它不僅記錄了package.json指明的直接依賴的版本,也記錄了間接依賴的版本。

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

當(dāng)package.json和package-lock.json同時存在時,npm install會去檢測package-lock.json指定的依賴版本是否在package.json指定的范圍內(nèi)。如果在,則安裝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指定的范圍內(nèi),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指定的范圍內(nèi),npm install會按照^2.2.0的規(guī)則去安裝最新的2.6.10版本,并且將package-lock.json的版本更新為2.6.10。

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

npm ci

npm5之后的lock機(jī)制滿足了要求鎖版本的開發(fā)者們的需要,我們只需要拿到一份package-lock.json就可以知道要安裝的依賴的具體版本號。但細(xì)心的同學(xué)會發(fā)現(xiàn)當(dāng)package-lock.json指定的版本號不在package.json指定的范圍內(nèi)時,package-lock.json就會被更新覆蓋。這可不利于我們?nèi)ゾS持版本的固定。

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

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

總結(jié)

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Node.js中的異步生成器與異步迭代詳解

    Node.js中的異步生成器與異步迭代詳解

    這篇文章主要給大家介紹了關(guān)于Node.js中異步生成器與異步迭代的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • 從零開始在webstorm配置nodejs

    從零開始在webstorm配置nodejs

    WebStorm是作為JS開發(fā)IDE存在的,并且支持流行的Node.js以及JQuery等js框架,下面這篇文章主要給大家介紹了關(guān)于如何從零開始在webstorm配置nodejs的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • 淺談Node.js中的定時器

    淺談Node.js中的定時器

    本文給大家分享的是Node.js中的定時器的相關(guān)資料,十分的全面細(xì)致,有需要的小伙伴可以參考下。
    2015-06-06
  • Node.js中的模塊機(jī)制學(xué)習(xí)筆記

    Node.js中的模塊機(jī)制學(xué)習(xí)筆記

    這篇文章主要介紹了Node.js中的模塊機(jī)制學(xué)習(xí)筆記,本文講解了CommonJS模塊規(guī)范、Node模塊實(shí)現(xiàn)過程、模塊調(diào)用棧、包與NPM等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • pnpm實(shí)現(xiàn)依賴包共享和依賴包項目隔離的方法詳解

    pnpm實(shí)現(xiàn)依賴包共享和依賴包項目隔離的方法詳解

    pnpm是Node.js的包管理器,它是 npm 的直接替代品,相對于npm和yarn它的優(yōu)點(diǎn)就在于速度快和高效節(jié)省磁盤空間,本文主要講解pnpm相比于npm/yarn如何利用軟硬鏈接來節(jié)省磁盤空間,以及如何實(shí)現(xiàn)依賴包共享和依賴包項目隔離的,需要的朋友可以參考下
    2024-05-05
  • Node.js事件的正確使用方法

    Node.js事件的正確使用方法

    這篇文章主要給大家介紹了關(guān)于Node.js事件的正確使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Node.js具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 傻瓜式解讀koa中間件處理模塊koa-compose的使用

    傻瓜式解讀koa中間件處理模塊koa-compose的使用

    這篇文章主要介紹了傻瓜式解讀koa中間件處理模塊koa-compose的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • Nodejs模塊載入運(yùn)行原理

    Nodejs模塊載入運(yùn)行原理

    本篇文章給大家詳細(xì)分享了Nodejs模塊載入運(yùn)行原理知識點(diǎn),對此有興趣的朋友可以跟著小編一起學(xué)習(xí)下。
    2018-02-02
  • NodeJS制作爬蟲全過程

    NodeJS制作爬蟲全過程

    這篇文章主要介紹了NodeJS制作爬蟲的全過程,包括項目建立,目標(biāo)網(wǎng)站分析、使用superagent獲取源數(shù)據(jù)、使用cheerio解析、使用eventproxy來并發(fā)抓取每個主題的內(nèi)容等方面,有需要的小伙伴參考下吧。
    2014-12-12
  • Node.js發(fā)出請求走Proxyman代理調(diào)試tip詳解

    Node.js發(fā)出請求走Proxyman代理調(diào)試tip詳解

    這篇文章主要為大家介紹了Node.js發(fā)出請求走Proxyman代理調(diào)試tip詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08

最新評論