安装

前言

If you don’t use the standalone script or @pnpm/exe to install pnpm, then you need to have Node.js (at least v16.14) to be installed on your system.

使用独立脚本安装

即使没有安装 Node.js,也可以使用以下脚本安装 pnpm。

Windows

使用 PowerShell:

  1. iwr https://get.pnpm.io/install.ps1 -useb | iex

在 POSIX 系统上

  1. curl -fsSL https://get.pnpm.io/install.sh | sh -

如果您没有安装 curl,也可以使用 wget:

  1. wget -qO- https://get.pnpm.io/install.sh | sh -

在 Alpine Linux 上

  1. # bash
  2. wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.bashrc" SHELL="$(which bash)" bash -
  3. # sh
  4. wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.shrc" SHELL="$(which sh)" sh -
  5. # dash
  6. wget -qO- https://get.pnpm.io/install.sh | ENV="$HOME/.dashrc" SHELL="$(which dash)" dash -

安装特定版本

在运行安装脚本之前,您可以选择设置环境变量 PNPM_VERSION 来安装特定版本的 pnpm:

  1. curl -fsSL https://get.pnpm.io/install.sh | env PNPM_VERSION=<version> sh -

安装 - 图1提示

然后您可以使用 pnpm env 命令来安装 Node.js。

使用 Corepack 安装

从 v16.13 开始,Node.js 发布了 Corepack 来管理包管理器。 这是一项实验性功能,因此您需要通过运行如下脚本来启用它:

  1. corepack enable

如果您使用 Homebrew 安装 Node.js,则需要单独安装 corepack:

  1. brew install corepack

这将自动在您的系统上安装 pnpm。 但是,它可能不是最新版本的 pnpm。 若要升级,请检查 最新的 pnpm 版本 并运行:

  1. corepack prepare pnpm@<version> --activate

使用 Node.js v16.17 或更高版本,您只需指定标签即可安装 最新 版本的 pnpm:

  1. corepack prepare pnpm@latest --activate

使用 npm 安装

We provide two packages of pnpm CLI, pnpm and @pnpm/exe.

  • pnpm is a ordinary version of pnpm, which needs Node.js to run.
  • @pnpm/exe is packaged with Node.js into an executable, so it may be used on a system with no Node.js installed.
  1. npm install -g pnpm

或者

  1. npm install -g @pnpm/exe

使用 HomeBrew 安装

如果安装了包管理器HomeBrew,则可以使用以下命令安装 pnpm:

  1. brew install pnpm

使用 Scoop 安装

如果您安装了 Scoop ,您可以使用以下命令安装 pnpm:

  1. scoop install nodejs-lts pnpm

安装 - 图2提示

如果您要在 CI 服务器上使用 pnpm ? 参阅: Continuous Integration.

兼容性

以下是各版本 pnpm 与各版本 Node.js 之间的兼容表格。

Node.jspnpm 5pnpm 6pnpm 7pnpm 8
Node.js 12✔️✔️
Node.js 14✔️✔️✔️
Node.js 16未知✔️✔️✔️
Node.js 18未知✔️✔️✔️

故障排查

如果 pnpm 损坏并且您无法通过重新安装来修复它,您可能需要从 PATH 中将其手动删除。

假设您在运行 pnpm install 时遇到以下错误:

  1. C:\src>pnpm install
  2. internal/modules/cjs/loader.js:883
  3. throw err;
  4. ^
  5. Error: Cannot find module 'C:\Users\Bence\AppData\Roaming\npm\pnpm-global\4\node_modules\pnpm\bin\pnpm.js'
  6. ←[90m at Function.Module._resolveFilename (internal/modules/cjs/loader.js:880:15)←[39m
  7. ←[90m at Function.Module._load (internal/modules/cjs/loader.js:725:27)←[39m
  8. ←[90m at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:72:12)←[39m
  9. ←[90m at internal/main/run_main_module.js:17:47←[39m {
  10. code: ←[32m'MODULE_NOT_FOUND'←[39m,
  11. requireStack: []
  12. }

首先,尝试通过运行 which pnpm 来找到 pnpm 的位置。 如果您使用的是 Windows,请在 Git Bash 中运行此命令。 您将获得 pnpm 命令的位置,例如:

  1. $ which pnpm
  2. /c/Program Files/nodejs/pnpm

现在您应该已经知道了 pnpm CLI 的所在目录。打开该目录并删除所有与 pnpm 相关的文件(如pnpm.cmdpnpx.cmdpnpm等)。 完成后,再次安装 pnpm。现在它应该按照预期正常工作。

使用较短的别名

pnpm 可能输入较长,因此您可以使用较短的别名,例如 pn

在 POSIX 系统上添加永久别名

只需将下面这行放入 .bashrc.zshrcconfig.fish中:

  1. alias pn=pnpm

在 Powershell (Windows) 中添加永久别名:

在具有管理员权限的 Powershell 窗口中,执行:

  1. notepad $profile.AllUsersAllHosts

profile.ps1 文件里加入:

  1. set-alias -name pn -value pnpm

保存文件然后关闭窗口。 您可能需要重新打开 Powershell 窗口才能使别名生效。

卸载 pnpm

如果您需要从系统中卸载 pnpm CLI 并移除磁盘中的相关文件,请查阅 卸载 pnpm