无法下载 node-sqlite3@4.2.0 - node-pre-gyp 错误尝试下载(403)拒绝访问 - node.js

Cannot download node-sqlite3@4.2.0 - node-pre-gyp ERROR Tried to download(403) Access Denied - node.js

我一直在尝试下载 sqlite3@4.2.0,但一直出现错误。这是尝试 运行 npm install:

时的日志
npm WARN deprecated node-pre-gyp@0.11.0: Please upgrade to @mapbox/node-pre-gyp: the non-scoped node-pre-gyp package is deprecated and only the @mapbox scoped package will recieve updates in the future

> sqlite3@4.2.0 install /Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3
> node-pre-gyp install --fallback-to-build

node-pre-gyp WARN Using needle for node-pre-gyp https download 
node-pre-gyp WARN Tried to download(403): https://mapbox-node-binary.s3.amazonaws.com/sqlite3/v4.2.0/node-v83-darwin-arm64.tar.gz 
node-pre-gyp WARN Pre-built binaries not found for sqlite3@4.2.0 and node@14.17.0 (node-v83 ABI, unknown) (falling back to source compile with node-gyp) 
No receipt for 'com.apple.pkg.CLTools_Executables' found at '/'.

No receipt for 'com.apple.pkg.DeveloperToolsCLILeo' found at '/'.

No receipt for 'com.apple.pkg.DeveloperToolsCLI' found at '/'.

gyp: No Xcode or CLT version detected!
gyp ERR! configure error 
gyp ERR! stack Error: `gyp` failed with exit code: 1
gyp ERR! stack     at ChildProcess.onCpExit (/Users/crypthusiast0/.nvm/versions/node/v14.17.0/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js:351:16)
gyp ERR! stack     at ChildProcess.emit (events.js:376:20)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:277:12)
gyp ERR! System Darwin 20.4.0
gyp ERR! command "/Users/crypthusiast0/.nvm/versions/node/v14.17.0/bin/node" "/Users/crypthusiast0/.nvm/versions/node/v14.17.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "configure" "--fallback-to-build" "--module=/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3/lib/binding/node-v83-darwin-arm64/node_sqlite3.node" "--module_name=node_sqlite3" "--module_path=/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3/lib/binding/node-v83-darwin-arm64" "--napi_version=8" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v83"
gyp ERR! cwd /Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3
gyp ERR! node -v v14.17.0
gyp ERR! node-gyp -v v5.1.0
gyp ERR! not ok 
node-pre-gyp ERR! build error 
node-pre-gyp ERR! stack Error: Failed to execute '/Users/crypthusiast0/.nvm/versions/node/v14.17.0/bin/node /Users/crypthusiast0/.nvm/versions/node/v14.17.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js configure --fallback-to-build --module=/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3/lib/binding/node-v83-darwin-arm64/node_sqlite3.node --module_name=node_sqlite3 --module_path=/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3/lib/binding/node-v83-darwin-arm64 --napi_version=8 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v83' (1)
node-pre-gyp ERR! stack     at ChildProcess.<anonymous> (/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/node-pre-gyp/lib/util/compile.js:83:29)
node-pre-gyp ERR! stack     at ChildProcess.emit (events.js:376:20)
node-pre-gyp ERR! stack     at maybeClose (internal/child_process.js:1055:16)
node-pre-gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:288:5)
node-pre-gyp ERR! System Darwin 20.4.0
node-pre-gyp ERR! command "/Users/crypthusiast0/.nvm/versions/node/v14.17.0/bin/node" "/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/.bin/node-pre-gyp" "install" "--fallback-to-build"
node-pre-gyp ERR! cwd /Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3
node-pre-gyp ERR! node -v v14.17.0
node-pre-gyp ERR! node-pre-gyp -v v0.11.0
node-pre-gyp ERR! not ok 
Failed to execute '/Users/crypthusiast0/.nvm/versions/node/v14.17.0/bin/node /Users/crypthusiast0/.nvm/versions/node/v14.17.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js configure --fallback-to-build --module=/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3/lib/binding/node-v83-darwin-arm64/node_sqlite3.node --module_name=node_sqlite3 --module_path=/Users/crypthusiast0/Dev/nodejs/auction-flipper/node_modules/sqlite3/lib/binding/node-v83-darwin-arm64 --napi_version=8 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v83' (1)
npm WARN node-auction-flipper@0.1.0 No repository field.
npm WARN node-auction-flipper@0.1.0 license should be a valid SPDX license expression

npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! sqlite3@4.2.0 install: `node - pre - gyp install--fallback - to - build`
npm ERR! Exit status 1
npm ERR!
npm ERR! Failed at the sqlite3@4.2.0 install script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.

npm ERR! A complete log of this run can be found in:
npm ERR!     /Users/crypthusiast0/.npm/_logs/2021-06-10T21_46_58_721Z-debug.log

我回头看了看日志,发现 https://mapbox-node-binary.s3.amazonaws.com/sqlite3/v4.2.0/node-v83-darwin-arm64.tar.gz 可能是造成这种情况的主要原因,因为如果你真的去 link,它会给你这个错误:

<Error>
<Code>AccessDenied</Code>
<Message>Access Denied</Message>
<RequestId>Q0JKD48B1117QG62</RequestId>
<HostId>0tR6ildiySR62EjZI4DwfeVbxSFIOClQUiIyMCySpd/lficx42uEJ2YU94GtQQvMnF4EENuWH/0=</HostId>
</Error>

我不太确定如何解决这个问题,因为我对 Node.js/NPM 和安装模块不是很有经验,但是我确实需要 node-sqlite3 具体版本 4.2.0因为我的一个 VSCode 扩展依赖于它。我找到了 node-sqlite 的 github 存储库和 4.2.0 源代码。有什么办法可以解决这个问题或从源代码编译模块吗?也许是因为我的节点 version/os 不支持它?我以前有过这个工作,所以我不确定。

我使用的是 MacBook Air M1 (ARM) 运行ning 节点版本 v16.3.0 和 npm 版本 v7.16.0。

要修复错误,请尝试以下操作:

  • 清理 npm 缓存

     npm cache clean
    
  • 运行 npm install 看看它是否工作

     npm install 
    

并且由于您没有告诉我们您正在使用的节点版本可能与未使用正确版本的节点有关,它提到 here node-sqlite3 v4.2.0 适用于:

  • Node.js v4.x、v6.x、v8.x、v10.x、v11.x、v12.x 和 v13.x.

所以你可以考虑使用正确版本的nodejs


或者

如果您尝试从源代码手动安装 node-sqlite3 v4.2.0。它实际上是可能的,正如 npm docs. Just make sure you are downloading the tarball file not the zip file one, in your case it should be this one

上提到的

将 tarball 移到它应该在的位置,然后简单地 运行 以下内容:

npm install node-sqlite3-4.2.0.tar.gz

或者更简单:

npm install https://github.com/mapbox/node-sqlite3/archive/refs/tags/v4.2.0.tar.gz

其他答案对我没有帮助。此外,我发现只需使用 yarn 而不是 npm 即可解决其他答案中提到的问题。

但是,该答案并未解决主要问题:

node-pre-gyp WARN Tried to download(403): https://mapbox-node-binary.s3.amazonaws.com/sqlite3/v4.2.0/node-*******.tar.gz

node-pre-gyp WARN Pre-built binaries not found

TL;DR

对我来说,升级到 latest sqlite3 (e.g. via yarn add "sqlite3@^5" (NOTE: this command does not work properly in powershell)) 可以解决这个问题。原因是:它发现这个版本的预构建二进制文件很好。

如果您(绝对)需要使用旧版本,则必须确保本地编译成功,如下所述。

除此之外,您还需要确保安装了 node 的较新版本,因为通常不会为过时的 Node 提供预构建的二进制文件版本(检查 node -v;建议:使用 volta 来管理您的节点版本)。

警告:当然,这些预构建的二进制文件也可能在不久的将来被包作者删除。希望他们至少会用更新的版本替换它们,而不是完全让它们离线。

说明

上面的错误消息表明 gyp 无法下载 系统特定的 预构建二进制文件(这与 npm 包裹)。因为它找不到预先构建的二进制文件,它会尝试在本地编译它们,这总是很混乱并且很容易出错。

  • 问:为什么找不到预编译的二进制文件?

    • 答:预构建的二进制文件不是那么容易管理,因为您需要它们的许多不同版本,而不仅仅是它们所针对的 npm 包的版本。通常,npm 包的每个主要版本 + 节点版本 + 操作系统 + instruction set architecture(例如 ARM 32 位与 x86 64 位等)都需要一个。似乎出于某种原因,Mapbox 决定不长期存储那些预构建的二进制文件。我确信他们过去曾在那里,但对于 4.2.0 版(可能还有许多其他版本),他们现在已经不在了。
    • 他们可能只为他们的 npm 软件包的最新主要版本保留所有这些不同的二进制文件,并擦除旧版本以节省存储空间 space。我还没有找到关于 on their repo.
    • 的任何文档
  • 问:如果无法下载预构建的二进制文件会怎样?

    • A: 事情变得很乱。它不是短暂下载,而是尝试在您的系统上编译它们,涉及复杂的系统级依赖关系迷宫。例如:
      • 对于 OP,编译失败的原因是:

        gyp: No Xcode or CLT version detected!

      • 在我的例子中,它失败了,因为(在 Windows),我没有安装 VS 2017(也没有安装它的可再发行组件)。
    • 一般来说,本地编译首先需要node-gyp配合,然后你还需要python和系统特定的C++编译器。如果你稍微Google,你会发现很多关于人们成功(和失败)让这样的本地编译工作的故事。可以针对本地编译,但获得预构建的二进制文件会使事情变得容易得多。