写在前面

npm采用语义化的版本号 semver 进行控制,让开发过程中依赖的获取和升级变得非常容易,但不严格的版本号控制,也带来了不确定性~~

  • npm 建议使用semver版本,部分包不遵循semver;
  • package.json 可以使用精确的版本号控制你的直接依赖包,但第三方依赖的包无法管理;
  • 在开发阶段执行得到的版本,和后续部署时得到的可能是不一致的,更不可控的是,你依赖的第三方包也有这样的情况会导致潜在的上线风险。

目前主流的版本控制使用的是 semver 语义化版本。即,X.Y.Z (主版本号.次版本号.修订号)

  • 主版本号:当你做了不兼容的 API 修改
  • 次版本号:当你做了向下兼容的功能性新增
  • 修订号:当你做了向下兼容的问题修正

也可以将先行版本号及版本编译信息可以加到“主版本号.次版本号.修订号”的后面,作为延伸。(v1.2.2-beta)

# 查看当前哪些包需要更新
$ npm outdated -g -depth=0
Package Current Wanted Latest
webpack 4.6.0 4.17.1 4.17.1
pm2 2.6.1 2.10.4 3.0.4
commitizen 2.9.6 2.10.1 2.10.1

安装依赖

npm install 会生成 package.json,以及 node_modules (依赖树)。

同一套 package.json 生成相同的 node_modules 吗?实际情况并非如此!

  • 不同的npm版本,安装算法可能存在差异;
  • 依赖包发布了新 semver-range 版本;
  • 某个依赖项的依赖发布了新版本,且其使用 ^1.2.3 方式,即使你的项目中制定了固定版本;
  • 安装的版本不在可用,或出现版本变异。

锁定依赖

默认情况下,当用 --save/-S 或者 --save-dev/-D 安装一个模块时,npm 通过脱字符(^)来限定所安装模块的主版本号。

方式一:prefix控制

符号 当运行 npm update 时,情况说明 备注
^1.5.1 【限制主版本号】允许安装版本号大于 1.5.1 但小于 2.0.0 版本的模块 默认
~1.5.1 【限制次要版本】 允许安装版本号大于 1.5.1 但小于 1.6.0 版本的模块 npm config set save-prefix="~"
1.5.1 【精确控制】允许安装版本号大于 1.5.1 npm config set save-exact true

所以,我们可以将需要安装的模块版本前缀默认设置成波浪号(~);对于那些偏执的认为任何更新(模块的行为)会破坏系统的人,可以配置npm仅安装精确版本号的模块。

方式二:shrinkwrap

另一个选择是,可以在项目中使用 shrinkwrap,在开发阶段依赖稳定后,运行如下命令:

npm shrinkwrap
npm shrinkwrap--dev # 将dev-dependencies计算在内

这会生成一个 shrinkwrap.json 文件,该文件包含了你正在使用的模块的指定版本。当运行 npm install时,该文件所指定的模块版本会覆盖 package.json 文件中所指定的版本。

注意问题:

  • shrinkwrap计算时是根据当前依赖安装的目录结构生成的,如果你不能保证package.json文件定义的依赖与node_modules下已安装的依赖是匹配、无冗余的,建议在执行shrinkwrap命令前清理依赖并重新安装(rm -rf node_modules && npm install)或精简依赖(npm prune)
  • 默认情况下,shrinkwrap只计算dependencies依赖,而不计算dev-dependencies,如果在生产环境也需要开发依赖或你的依赖分类不清晰,使用--dev参数生成shrinkwrap文件确保不会出问题。

增加、更新、删除包的步骤如下:

第一步: 安装指定版本包 npm install/uninstall package_name@version --save

第二步: 测试功能,功能正常后,执行 npm shrinkwrap 把依赖写入 shrinkwrap 文件;

第三步: 在代码库中提交 shrinkwrap / package.json 描述。

版本控制

package-lock.json

对于 node_modules 或 package.json 的任何修改,都会自动生成 package-lock.json。它描述了生成的确切树,以便后续安装能够生成相同的树,而不管中间依赖性更新

shrinkwrap.json

为防止出现这种潜在问题,npm使用 package-lock.jsonnpm-shrinkwrap.json(如果存在)。这些文件称为包锁或锁文件。

{"name": "A","version": "0.1.0",...metadata fields..."dependencies": {"B": {"version": "0.0.1","resolved": "https://registry.npmjs.org/B/-/B-0.0.1.tgz","integrity": "sha512-DeAdb33F+""dependencies": {"C": {"version": "git://github.com/org/C.git#5c380ae319fc4efe9e7f2d9c78b0faa588fd99b4"}}}}
}

该文件描述了一个精确的、可重现的 node_modules 树。一旦它出现,任何未来的安装将基于此文件的工作,而不是从 package.json 重新计算依赖版本。此外,如果 package-lock.jsonnpm-shrinkwrap.json 都存在于包根目录中,则将忽略 package-lock.json

npm installnpm rmnpm update 等都将自动同步现有的锁文件。为了防止发生这种更新,你可以使用--no-save 选项来防止完全保存,或者 --no-shrinkwrap 允许更新 package.json 保留 package-lock.jsonnpm-shrinkwrap.json

注意:强烈建议库作者不要发布此文件,因为这会阻止最终用户控制传递依赖性更新。

问题补充

npm@5、npm@6 版本对于 requires 机制差异!(下图左侧npm@5,右侧npm@6)

是由于官方对其处理方式做了变更:
相关社区讨论:https://npm.community/t/package-lock-json-contains-dynamic-version/6080/9
相关ChangeLog说明:https://github.com/npm/cli/blob/latest/CHANGELOG.md#new-features-7

npm-shrinkwrap锁定依赖相关推荐

  1. npm 重新安装依赖_npm-shrinkwrap锁定依赖

    写在前面 npm采用语义化的版本号 semver 进行控制,让开发过程中依赖的获取和升级变得非常容易,但不严格的版本号控制,也带来了不确定性~~ npm 建议使用semver版本,部分包不遵循semv ...

  2. npm锁定依赖的版本号

    命令行运行 npm config set save-exact true 这样每次 npm i xxx --save 的时候会锁定依赖的版本号,相当于加了 --save-exact 参数. 小提示:n ...

  3. npm是如何处理依赖关系的

    首先我们在仓库 test 中 npm init 一个 package.json,然后 npm install react@16.13.1,此时 node_modules 的目录结构如下: testno ...

  4. npm i 下载依赖一直报错:git dep preparation failed等

    npm 报错:git dep preparation failed 前言 由于工作需要,重新换了工位,之前用的电脑也要退回公司,租借时间满了,现在用的是同事的电脑进行开发.要重新配置环境,但是在git ...

  5. npm删除项目所有依赖和清缓存清缓存的办法

    npm删除项目所有依赖和清缓存 清缓存的办法,一个是 npm cache verify, 还有一个方法npm cache clean --force 删除项目所有依赖  npm uninstall *

  6. 如何使用npm更新项目依赖包

    NPM(Node Package Manager,结点包管理)是一款用于管理 Node.js 依赖包的工具.通过 NPM,开发者可以快速地安装.卸载.更新等项目所需的依赖包,从而有效提高开发效率.节省 ...

  7. 用npm安装bootstrap以及通过npm下载项目依赖的包的过程

    npm安装bootstrap 1.建立项目后,在项目终端输入: npm init 会初始化一个package.json,并生成一个node_modules文件夹. 2.在package.jspn中的d ...

  8. npm命令--安装依赖包--用法/详解

    原文网址:npm命令--安装依赖包--用法/详解_IT利刃出鞘的博客-CSDN博客 简介 本文介绍npm如何安装依赖包. 用法 命令 作用 详述 npm install <pkg> //同 ...

  9. 使用npm install安装依赖报错

    项目场景: 我是安装express脚手架时遇到的,安装proj4库时也遇到了,所以在这里记录一下 问题描述: 使用npm install安装依赖报错,提示信息是 The package-lock.js ...

最新文章

  1. 【点云论文速读】点云高质量3D表面重建
  2. insight-vmi 编译中的问题
  3. Typescript中class的extends码源分析
  4. 一、express 路由 todos案例
  5. Linux 64位进程地址空间分布概况
  6. 公安信息通信网边界接入平台安全规范_【市场动态】3.56 亿元,阿里云中标青岛智慧公安项目...
  7. plsql打开sql窗口快捷键_可以提升3倍开发效率的 Intellij IDEA快捷键大全汇总(2019)...
  8. 区块容量 以太坊 比特币
  9. Ubuntu中超级终端-minicom
  10. 樽海鞘算法(Salp Swarm Algorithm: SSA)
  11. 51中断编程c语言,有关51单片机中断的形式和C语言编程格式[精选5篇]
  12. 自动收发短信验证码机器人_除了验证码:禁止机器人!
  13. 网吧游戏服务器制作教程,图文教程:网吧无盘系统服务端设置细节
  14. 元宇宙:从现实到虚无祛魅的产物|广州华锐互动
  15. banner文字生成器 横幅文字生成器
  16. 学习笔记-B/S - Exploits
  17. 一种快速锁定的 Fractional PLL 设计
  18. 【知识图谱】两种 Python 方法实现社区发现之标签传播算法(LPA)
  19. 作为一个技术Leader,要如何去提升团队的技术氛围
  20. 云、AI、5G技术驱动时代,文娱产业如何实现云上突围?

热门文章

  1. 解决elasticsearch开启外网访问,绑定IP下,浏览器访问超时问题
  2. 【ICML2022】LightNAS系列解读之一:基于最大熵原理的目标检测搜索方法MAE-Det
  3. 小米linux终端,Android里运行ubuntu的方法(以小米2S为例)
  4. word中如何修改脚注上方短横线的格式?
  5. GL_INTERFACE(转载)
  6. flume报错WARN clients.NetworkClient: Error while fetching metadata with correlation id
  7. UserWarning: invalid index of a 0-dim tensor
  8. 【亲测有效】win10任务栏右下角倒三角不见了?
  9. 服务器监控报警系统软件设计,基于E—mail的远程监控系统报警软件设计.doc
  10. 5382-49-0/1,2,3,4-四氢喹啉-6-甲酸/6-异丙基-1,2,3,4-四氢喹啉-分子量:177.200