跳到主要内容

项目初衷

节省磁盘空间

一个 pnpm 可寻址仓库的插��图。 在插图中有两个带有 node_modules 的项目。 node_modules 目录中的文件是指向内容可寻址仓库中相同文件的硬链接。

使用 npm 时,依赖每次被不同的项目使用,都会重复安装一次。  而在使用 pnpm 时,依赖会被存储在内容可寻址的存储中,所以:

  1. 如果你用到了某依赖项的不同版本,只会将不同版本间有差异的文件添加到仓库。 例如,如果某个包有100个文件,而它的新版本只改变了其中1个文件。那么 pnpm update 时只会向存储中心额外添加1个新文件,而不会因为仅仅一个文件的改变复制整新版本包的内容。
  2. 所有文件都会存储在硬盘上的某一位置。 当软件包被被安装时,包里的文件会硬链接到这一位置,而不会占用额外的磁盘空间。 这允许你跨项目地共享同一版本的依赖。

因此,您在磁盘上节省了大量空间,这与项目和依赖项的数量成正比,并且安装速度要快得多!

提高安装速度

pnpm 分三个阶段执行安装:

  1. 依赖解析。 仓库中没有的依赖都被识别并获取到仓库。
  2. 目录结构计算。 node_modules 目录结构是根据依赖计算出来的。
  3. 链接依赖项。 所有以前安装过的依赖项都会直接从仓库中获取并链接到 node_modules

pnpm 安装过程的插图。 所有的包会尽快解吸、获取和硬链接。

这种方法比传统的三阶段安装过程(解析、获取和将所有依赖项写入node_modules)快得多。

一个 Yarn Classic 或 npm 这样的包管理器如何安装依赖项的示意图。

创建一个非扁平的 node_modules 目录

使用 npm 或 Yarn Classic 安装依赖项时,所有的包都被提升到模块目录的根目录。 这样就导致了一个问题,源码可以直接访问和修改依赖,而不是作为只读的项目依赖。

默认情况下,pnpm 使用符号链接将项目的直接依赖项添加到模块目录的根目录中。

pnpm 创建的 node_modules 目录的图示。 根目录下的 node_modules 中的包是指向 node_modules/.pnpm 目录内目录的符号链接。

如果您想了解有关 pnpm 创建的独特的 node_modules 结构以及为什么它可以与 Node.js 生态系统良好地配合使用的更多细节,请阅读以下内容:

提示

如果您的工具不适用于符号链接,您仍然可以使用 pnpm 并将 node-linker 设置设置为 hoisted。 这样 pnpm 就会创建一个类似于 npm 和 Yarn Classic 创建的 node_modules 目录。