node.js - nodejs/electron-forge/node-gyp : Could not find any Visual Studio installation to use after trying all the tips I could find online

标签 node.js visual-studio npm electron node-gyp

介绍
在在线咨询了数百万条提示后,包括

  • How can I solve error gypgyp ERR!ERR! find VSfind VS msvs_version not set from command line or npm config?
  • https://github.com/nodejs/node-gyp/issues/1663
  • Not looking for VS2013 npm install node modules
  • Unable to install npm package (kafka-streams)

  • this "comprehensive guide" 介绍了与官方文档背道而驰的想法
    我仍然无法安装某些需要通过 npm 或 yarn 进行本地构建的第三方包。我也没有收到来自 nodejsnode-gyp github 问题论坛的任何回复。
    我即将发布一个已经在 macOS 上使用 electron-forge 构建良好的应用程序,但无法在 Windows 上运行。
    主要问题是用于构建第三方包的 npm 依赖项之一 node-gyp 在我的机器上找不到 Visual Studio。我使用 VS2017 Community 并为 node-gyp 安装了所有必需的组件。
    我的设置
  • Node 版本 :node -v =v12.18.3 和 npm -v =6.14.8
  • 平台 :systeminfo | findstr /B /C:"OS Name" /C:"OS Version" /C:"System Type" (Windows)
  • OS Name:                   Microsoft Windows 10 Pro
    OS Version:                10.0.18362 N/A Build 18362
    System Type:               x64-based PC
    
  • 编译器 :msbuild /version & cl (Windows)
  • Microsoft (R) Build Engine version 15.9.21+g9802d43bc3 for .NET Framework
    Copyright (C) Microsoft Corporation. All rights reserved.
    
    15.9.21.664Microsoft (R) C/C++ Optimizing Compiler Version 19.16.27043 for x64
    Copyright (C) Microsoft Corporation.  All rights reserved.
    
    usage: cl [ option... ] filename... [ /link linkoption... ]
    
  • 模块 :zeromq

  • 详细输出(来自 npm 或 node-gyp):
    me@me-PC0 D:\Desktop\myapp
    # node-gyp configure --msvs_version=2017
    gyp info it worked if it ends with ok
    gyp info using node-gyp@7.1.0
    gyp info using node@12.18.3 | win32 | x64
    gyp info find Python using Python version 3.8.5 found at "C:\Python\Python38\python.exe"
    gyp ERR! find VS
    gyp ERR! find VS msvs_version was set from command line or npm config
    gyp ERR! find VS - looking for Visual Studio version 2017
    gyp ERR! find VS running in VS Command Prompt, installation path is:
    gyp ERR! find VS "C:\Program Files (x86)\Microsoft Visual Studio\2017"
    gyp ERR! find VS - will only use this version
    gyp ERR! find VS could not use PowerShell to find Visual Studio 2017 or newer
    gyp ERR! find VS looking for Visual Studio 2015
    gyp ERR! find VS - found in "C:\Program Files (x86)\Microsoft Visual Studio 14.0"
    gyp ERR! find VS - could not find MSBuild in registry for this version
    gyp ERR! find VS not looking for VS2013 as it is only supported up to Node.js 8
    gyp ERR! find VS msvs_version does not match this VS Command Prompt or the
    gyp ERR! find VS installation cannot be used.
    gyp ERR! find VS
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS You need to install the latest version of Visual Studio
    gyp ERR! find VS including the "Desktop development with C++" workload.
    gyp ERR! find VS For more information consult the documentation at:
    gyp ERR! find VS https://github.com/nodejs/node-gyp#on-windows
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS
    gyp ERR! configure error
    gyp ERR! stack Error: Could not find any Visual Studio installation to use
    gyp ERR! stack     at VisualStudioFinder.fail (C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\find-visualstudio.js:121:47)
    gyp ERR! stack     at C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\find-visualstudio.js:74:16
    gyp ERR! stack     at VisualStudioFinder.findVisualStudio2013 (C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\find-visualstudio.js:351:14)
    gyp ERR! stack     at C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\find-visualstudio.js:70:14
    gyp ERR! stack     at C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\find-visualstudio.js:384:20
    gyp ERR! stack     at C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\util.js:54:7
    gyp ERR! stack     at C:\Users\me\AppData\Roaming\npm\node_modules\node-gyp\lib\util.js:33:16
    gyp ERR! stack     at ChildProcess.exithandler (child_process.js:310:5)
    gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
    gyp ERR! stack     at maybeClose (internal/child_process.js:1021:16)
    gyp ERR! System Windows_NT 10.0.18362
    gyp ERR! command "C:\\Apps\\nodejs\\node.exe" "C:\\Users\\me\\AppData\\Roaming\\npm\\node_modules\\node-gyp\\bin\\node-gyp.js" "configure" "--msvs_version=2017"
    gyp ERR! cwd D:\Desktop\myapp
    gyp ERR! node -v v12.18.3
    gyp ERR! node-gyp -v v7.1.0
    gyp ERR! not ok
    

    我尝试无济于事的事情
  • Desktop Development Kit for C++ 重新安装 VS 2017
  • 重新安装 Node 和npm
  • 在管理员 CMD、管理员 PowerShell、管理员 VC2017 开发命令提示符中运行相同的命令
  • 手动设置VCINSTALLDIR环境变量为:C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\
  • 运行 npm config set msvs_version 2017 --global ,然后 npm config get msvs_version 给我 2017
  • 每一步都重启电脑

  • 我在每一步都遇到了与上述相同的错误。
    进一步的尝试
    我已经完成了整个 nodejs 安装并重新开始,但问题仍然存在。我做了什么
  • 基于 this StackOverflow answer 删除了 nodejs。
  • 使用来自官方 nodejs 站点的 .msi 安装程序重新安装了适用于 Windows v12.18.3 的 nodejs x64,允许安装程序安装额外的依赖项,例如巧克力
  • 使用 electron-forge 创建了一个空白 Electron 应用程序:像这样

  • me@me-PC0 D:\Desktop
    $ npx create-electron-app myapp
    √ Initializing Project Directory
    √ Initializing Git Repository
    √ Locating custom template: "base"
    √ Copying Starter Files
    √ Initializing NPM Module
    √ Installing Template Dependencies
    √ Installing NPM Dependencies
    
    me@me-PC0 D:\Desktop
    $ cd myapp
    
    me@me-PC0 D:\Desktop\myapp
    $ npm start
    
    > myapp@1.0.0 start D:\Desktop\myapp
    > electron-forge start
    
    √ Checking your system
    √ Locating Application
    √ Preparing native dependencies
    √ Launching Application
    
    
  • npm 使用的已配置 VS 版本:npm config set msvs_version 2017npm config set msvs_version 2017 --global

  • 应用程序一直运行到这一点。然后 ...
  • 安装依赖 zeromq

  • $ npm install zeromq --save-prod
    npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142
    npm WARN deprecated har-validator@5.1.5: this library is no longer supported
    npm WARN rm not removing D:\Desktop\myapp\node_modules\.bin\extract-zip.cmd as it wasn't installed by D:\Desktop\myapp\node_modules\extract-zip
    npm WARN rm not removing D:\Desktop\myapp\node_modules\.bin\extract-zip as it wasn't installed by D:\Desktop\myapp\node_modules\extract-zip
    npm WARN rm not removing D:\Desktop\myapp\node_modules\.bin\rimraf.cmd as it wasn't installed by D:\Desktop\myapp\node_modules\rimraf
    npm WARN rm not removing D:\Desktop\myapp\node_modules\.bin\rimraf as it wasn't installed by D:\Desktop\myapp\node_modules\rimraf
    npm WARN rm not removing D:\Desktop\myapp\node_modules\.bin\semver.cmd as it wasn't installed by D:\Desktop\myapp\node_modules\semver
    npm WARN rm not removing D:\Desktop\myapp\node_modules\.bin\semver as it wasn't installed by D:\Desktop\myapp\node_modules\semver
    
    > zeromq@6.0.0-beta.6 install D:\Desktop\myapp\node_modules\zeromq
    > node-gyp-build
    
    
    > core-js@3.6.5 postinstall D:\Desktop\myapp\node_modules\core-js
    > node -e "try{require('./postinstall')}catch(e){}"
    
    Thank you for using core-js ( https://github.com/zloirock/core-js ) for polyfilling JavaScript standard library!
    
    The project needs your help! Please consider supporting of core-js on Open Collective or Patreon:
    > https://opencollective.com/core-js
    > https://www.patreon.com/zloirock
    
    Also, the author of core-js ( https://github.com/zloirock ) is looking for a good job -)
    
    npm notice created a lockfile as package-lock.json. You should commit this file.
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: electron-installer-debian@^3.0.0 (node_modules\@electron-forge\maker-deb\node_modules\electron-installer-debian):
    npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for electron-installer-debian@3.1.0: wanted {"os":"darwin,linux","arch":"any"} (current: {"os":"win32","arch":"x64"})
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: electron-installer-redhat@^3.2.0 (node_modules\@electron-forge\maker-rpm\node_modules\electron-installer-redhat):
    npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for electron-installer-redhat@3.2.0: wanted {"os":"darwin,linux","arch":"any"} (current: {"os":"win32","arch":"x64"})
    npm WARN myapp@1.0.0 No repository field.
    
    + zeromq@6.0.0-beta.6
    added 50 packages from 7 contributors, removed 32 packages, updated 401 packages and audited 460 packages in 61.306s
    
    32 packages are looking for funding
      run `npm fund` for details
    
    found 0 vulnerabilities
    
  • 运行 electron-forge 构建 Windows 发行版。

  • $ npm run make
    
    > myapp@1.0.0 make D:\Desktop\myapp
    > electron-forge make
    
    √ Checking your system
    √ Resolving Forge Config
    We need to package your application before we can make it
    √ Preparing to Package Application for arch: x64
    × Preparing native dependencies: 0 / 1
    
    An unhandled error has occurred inside Forge:
    Command failed with a non-zero return code (1):
    D:\Desktop\myapp\node_modules\electron-rebuild\node_modules\.bin\node-gyp.cmd rebuild --target=10.1.0 --arch=x64 --dist-url=https://www.electronjs.org/headers --build-from-source
    
    gyp ERR! find VS
    gyp ERR! find VS msvs_version was set from command line or npm config
    gyp ERR! find VS - looking for Visual Studio version 2017
    gyp ERR! find VS VCINSTALLDIR not set, not running in VS Command Prompt
    gyp ERR! find VS could not use PowerShell to find Visual Studio 2017 or newer
    gyp ERR! find VS looking for Visual Studio 2015
    gyp ERR! find VS - found in "C:\Program Files (x86)\Microsoft Visual Studio 14.0"
    gyp ERR! find VS - could not find MSBuild in registry for this version
    gyp ERR! find VS not looking for VS2013 as it is only supported up to Node.js 8
    gyp ERR! find VS
    gyp ERR! find VS valid versions for msvs_version:
    gyp ERR! find VS
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS You need to install the latest version of Visual Studio
    gyp ERR! find VS including the "Desktop development with C++" workload.
    gyp ERR! find VS For more information consult the documentation at:
    gyp ERR! find VS https://github.com/nodejs/node-gyp#on-windows
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS
    gyp ERR! configure error
    gyp ERR! stack Error: Could not find any Visual Studio installation to use
    gyp ERR! stack     at VisualStudioFinder.fail (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:121:47)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:74:16
    gyp ERR! stack     at VisualStudioFinder.findVisualStudio2013 (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:351:14)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:70:14
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:384:20
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:54:7
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:33:16
    gyp ERR! stack     at ChildProcess.exithandler (child_process.js:310:5)
    gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
    gyp ERR! stack     at maybeClose (internal/child_process.js:1021:16)
    gyp ERR! System Windows_NT 10.0.18362
    gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "D:\\Desktop\\myapp\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild" "--target=10.1.0" "--arch=x64" "--dist-url=https://www.electronjs.org/headers" "--build-from-source"
    gyp ERR! cwd C:\Users\me\AppData\Local\Temp\electron-packager\win32-x64\myapp-win32-x64\resources\app\node_modules\zeromq
    gyp ERR! node -v v12.18.3
    gyp ERR! node-gyp -v v7.1.0
    gyp ERR! not ok
    Error: Command failed with a non-zero return code (1):
    D:\Desktop\myapp\node_modules\electron-rebuild\node_modules\.bin\node-gyp.cmd rebuild --target=10.1.0 --arch=x64 --dist-url=https://www.electronjs.org/headers --build-from-source
    
    gyp ERR! find VS
    gyp ERR! find VS msvs_version was set from command line or npm config
    gyp ERR! find VS - looking for Visual Studio version 2017
    gyp ERR! find VS VCINSTALLDIR not set, not running in VS Command Prompt
    gyp ERR! find VS could not use PowerShell to find Visual Studio 2017 or newer
    gyp ERR! find VS looking for Visual Studio 2015
    gyp ERR! find VS - found in "C:\Program Files (x86)\Microsoft Visual Studio 14.0"
    gyp ERR! find VS - could not find MSBuild in registry for this version
    gyp ERR! find VS not looking for VS2013 as it is only supported up to Node.js 8
    gyp ERR! find VS
    gyp ERR! find VS valid versions for msvs_version:
    gyp ERR! find VS
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS You need to install the latest version of Visual Studio
    gyp ERR! find VS including the "Desktop development with C++" workload.
    gyp ERR! find VS For more information consult the documentation at:
    gyp ERR! find VS https://github.com/nodejs/node-gyp#on-windows
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS
    gyp ERR! configure error
    gyp ERR! stack Error: Could not find any Visual Studio installation to use
    gyp ERR! stack     at VisualStudioFinder.fail (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:121:47)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:74:16
    gyp ERR! stack     at VisualStudioFinder.findVisualStudio2013 (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:351:14)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:70:14
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:384:20
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:54:7
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:33:16
    gyp ERR! stack     at ChildProcess.exithandler (child_process.js:310:5)
    gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
    gyp ERR! stack     at maybeClose (internal/child_process.js:1021:16)
    gyp ERR! System Windows_NT 10.0.18362
    gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "D:\\Desktop\\myapp\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild" "--target=10.1.0" "--arch=x64" "--dist-url=https://www.electronjs.org/headers" "--build-from-source"
    gyp ERR! cwd C:\Users\me\AppData\Local\Temp\electron-packager\win32-x64\myapp-win32-x64\resources\app\node_modules\zeromq
    gyp ERR! node -v v12.18.3
    gyp ERR! node-gyp -v v7.1.0
    gyp ERR! not ok
        at ChildProcess.<anonymous> (D:\Desktop\myapp\node_modules\@malept\cross-spawn-promise\src\index.ts:155:16)
        at ChildProcess.emit (events.js:315:20)
        at ChildProcess.EventEmitter.emit (domain.js:483:12)
        at ChildProcess.cp.emit (D:\Desktop\myapp\node_modules\cross-spawn\lib\enoent.js:34:29)
        at maybeClose (internal/child_process.js:1021:16)
        at Process.ChildProcess._handle.onexit (internal/child_process.js:286:5)
    npm ERR! code ELIFECYCLE
    npm ERR! errno 1
    npm ERR! myapp@1.0.0 make: `electron-forge make`
    npm ERR! Exit status 1
    npm ERR!
    npm ERR! Failed at the myapp@1.0.0 make 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!     C:\Users\me\AppData\Roaming\npm-cache\_logs\2020-08-28T04_35_43_345Z-debug.log
    
    
  • 尝试通过手动设置 VCINSTALLDIR 环境变量来解决此问题

  • set VCINSTALLDIR=C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\
    
  • 然后再次运行electron-forge

  • D:\Desktop\myapp>npm run make
    
    > myapp@1.0.0 make D:\Desktop\myapp
    > electron-forge make
    
    √ Checking your system
    √ Resolving Forge Config
    We need to package your application before we can make it
    √ Preparing to Package Application for arch: x64
    × Preparing native dependencies: 0 / 1
    
    An unhandled error has occurred inside Forge:
    Command failed with a non-zero return code (1):
    D:\Desktop\myapp\node_modules\electron-rebuild\node_modules\.bin\node-gyp.cmd rebuild --target=10.1.0 --arch=x64 --dist-url=https://www.electronjs.org/headers --build-from-source
    
    gyp ERR! find VS
    gyp ERR! find VS msvs_version was set from command line or npm config
    gyp ERR! find VS - looking for Visual Studio version 2017
    gyp ERR! find VS running in VS Command Prompt, installation path is:
    gyp ERR! find VS "C:\Program Files (x86)\Microsoft Visual Studio\2017"
    gyp ERR! find VS - will only use this version
    gyp ERR! find VS could not use PowerShell to find Visual Studio 2017 or newer
    gyp ERR! find VS looking for Visual Studio 2015
    gyp ERR! find VS - found in "C:\Program Files (x86)\Microsoft Visual Studio 14.0"
    gyp ERR! find VS - could not find MSBuild in registry for this version
    gyp ERR! find VS not looking for VS2013 as it is only supported up to Node.js 8
    gyp ERR! find VS msvs_version does not match this VS Command Prompt or the
    gyp ERR! find VS installation cannot be used.
    gyp ERR! find VS
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS You need to install the latest version of Visual Studio
    gyp ERR! find VS including the "Desktop development with C++" workload.
    gyp ERR! find VS For more information consult the documentation at:
    gyp ERR! find VS https://github.com/nodejs/node-gyp#on-windows
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS
    gyp ERR! configure error
    gyp ERR! stack Error: Could not find any Visual Studio installation to use
    gyp ERR! stack     at VisualStudioFinder.fail (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:121:47)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:74:16
    gyp ERR! stack     at VisualStudioFinder.findVisualStudio2013 (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:351:14)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:70:14
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:384:20
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:54:7
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:33:16
    gyp ERR! stack     at ChildProcess.exithandler (child_process.js:310:5)
    gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
    gyp ERR! stack     at maybeClose (internal/child_process.js:1021:16)
    gyp ERR! System Windows_NT 10.0.18362
    gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "D:\\Desktop\\myapp\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild" "--target=10.1.0" "--arch=x64" "--dist-url=https://www.electronjs.org/headers" "--build-from-source"
    gyp ERR! cwd C:\Users\me\AppData\Local\Temp\electron-packager\win32-x64\myapp-win32-x64\resources\app\node_modules\zeromq
    gyp ERR! node -v v12.18.3
    gyp ERR! node-gyp -v v7.1.0
    gyp ERR! not ok
    Error: Command failed with a non-zero return code (1):
    D:\Desktop\myapp\node_modules\electron-rebuild\node_modules\.bin\node-gyp.cmd rebuild --target=10.1.0 --arch=x64 --dist-url=https://www.electronjs.org/headers --build-from-source
    
    gyp ERR! find VS
    gyp ERR! find VS msvs_version was set from command line or npm config
    gyp ERR! find VS - looking for Visual Studio version 2017
    gyp ERR! find VS running in VS Command Prompt, installation path is:
    gyp ERR! find VS "C:\Program Files (x86)\Microsoft Visual Studio\2017"
    gyp ERR! find VS - will only use this version
    gyp ERR! find VS could not use PowerShell to find Visual Studio 2017 or newer
    gyp ERR! find VS looking for Visual Studio 2015
    gyp ERR! find VS - found in "C:\Program Files (x86)\Microsoft Visual Studio 14.0"
    gyp ERR! find VS - could not find MSBuild in registry for this version
    gyp ERR! find VS not looking for VS2013 as it is only supported up to Node.js 8
    gyp ERR! find VS msvs_version does not match this VS Command Prompt or the
    gyp ERR! find VS installation cannot be used.
    gyp ERR! find VS
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS You need to install the latest version of Visual Studio
    gyp ERR! find VS including the "Desktop development with C++" workload.
    gyp ERR! find VS For more information consult the documentation at:
    gyp ERR! find VS https://github.com/nodejs/node-gyp#on-windows
    gyp ERR! find VS **************************************************************
    gyp ERR! find VS
    gyp ERR! configure error
    gyp ERR! stack Error: Could not find any Visual Studio installation to use
    gyp ERR! stack     at VisualStudioFinder.fail (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:121:47)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:74:16
    gyp ERR! stack     at VisualStudioFinder.findVisualStudio2013 (D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:351:14)
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:70:14
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js:384:20
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:54:7
    gyp ERR! stack     at D:\Desktop\myapp\node_modules\node-gyp\lib\util.js:33:16
    gyp ERR! stack     at ChildProcess.exithandler (child_process.js:310:5)
    gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
    gyp ERR! stack     at maybeClose (internal/child_process.js:1021:16)
    gyp ERR! System Windows_NT 10.0.18362
    gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "D:\\Desktop\\myapp\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild" "--target=10.1.0" "--arch=x64" "--dist-url=https://www.electronjs.org/headers" "--build-from-source"
    gyp ERR! cwd C:\Users\me\AppData\Local\Temp\electron-packager\win32-x64\myapp-win32-x64\resources\app\node_modules\zeromq
    gyp ERR! node -v v12.18.3
    gyp ERR! node-gyp -v v7.1.0
    gyp ERR! not ok
        at ChildProcess.<anonymous> (D:\Desktop\myapp\node_modules\@malept\cross-spawn-promise\src\index.ts:155:16)
        at ChildProcess.emit (events.js:315:20)
        at ChildProcess.EventEmitter.emit (domain.js:483:12)
        at ChildProcess.cp.emit (D:\Desktop\myapp\node_modules\cross-spawn\lib\enoent.js:34:29)
        at maybeClose (internal/child_process.js:1021:16)
        at Process.ChildProcess._handle.onexit (internal/child_process.js:286:5)
    npm ERR! code ELIFECYCLE
    npm ERR! errno 1
    npm ERR! myapp@1.0.0 make: `electron-forge make`
    npm ERR! Exit status 1
    npm ERR!
    npm ERR! Failed at the myapp@1.0.0 make 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!     C:\Users\me\AppData\Roaming\npm-cache\_logs\2020-08-28T04_40_16_364Z-debug.log
    
    
  • 还试图在 D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js 处破解 node-gyp 的 Visual Studio 定位器代码,以将 amd64 插入到


  • if (versionYear === 2017) {
            return path.join(info.path, 'MSBuild', '15.0', 'Bin', 'MSBuild.exe')
    }
    if (versionYear === 2019) {
        return path.join(info.path, 'MSBuild', 'Current', 'Bin', 'MSBuild.exe')
    }
    
    使他们成为
    if (versionYear === 2017) {
            return path.join(info.path, 'MSBuild', '15.0', 'Bin', 'amd64', 'MSBuild.exe')
    }
    if (versionYear === 2019) {
            return path.join(info.path, 'MSBuild', 'Current', 'Bin', 'amd64', 'MSBuild.exe')
    }
    
  • 然后再次运行 npm run make。与上一步相同的错误。

  • 这是我的构建环境
    D:\Desktop\myapp>npm config get msvs_version
    2017
    
    D:\Desktop\myapp>npm config get python
    C:\Python\Python38\pythonw.exe
    
    Python 3.8 是来自 python.org 的 64 位版本。
    问题
    我错过了什么?我应该忘记VS2017吗?我的项目使用 VS2017 进行 C++ 开发,所以恐怕我无法更改。但是我应该安装VS2015吗?
    令人困惑的是,在 node-gyp README.md 上,它首先说

    Launch cmd, npm config set msvs_version 2017


    然后稍后在 How to Use 中,它会说:
    Auto-detection fails for Visual C++ Build Tools 2015, so --msvs_version=2015 needs to be added (not needed when run by npm as configured above):
    
    $ node-gyp configure --msvs_version=2015
    
    这个版本差异是怎么回事?

    最佳答案

    终于自己弄明白了。
    罪魁祸首
    Visual Studio 环境变量 LIB在我的本地机器上被污染了。里面有些路径有一些非法字符,导致node-gyp解析问题。修复这些字符后,问题就消失了。
    此外,node-gyp 中的 64 位修复我在问题中提到的来源是必要的:

    // D:\Desktop\myapp\node_modules\node-gyp\lib\find-visualstudio.js
    
    if (versionYear === 2017) {
        return path.join(info.path, 'MSBuild', '15.0', 'Bin', 'amd64', 'MSBuild.exe')
    }
    if (versionYear === 2019) {
        return path.join(info.path, 'MSBuild', 'Current', 'Bin', 'amd64', 'MSBuild.exe')
    }
    
    我是怎么找到的
    我真的不得不进入node-gyp源代码来定位问题。它定位 Visual Studio 安装的方式是通过调用另一个 C# 脚本 Find-VisualStudio.cs 的 PowerShell 命令。执行操作系统查询工作。
    不幸的是,这个 PowerShell 命令的错误日志没有立即反射(reflect)在 node-gyp 中。或 npm日志。 在我拉出命令并在 PowerShell 中运行它之后,瞧! PowerShell 命令运行的底层系统日志显示我的 LIB 有问题多变的。
    道德课
  • 经验法则:保持 Visual Studio 环境变量不变。
  • JS/node 生态系统具有复杂的依赖关系。您必须通过进入源代码来了解发生了什么。
  • 鉴于生态系统的绝对速度,过时的提示实际上可能会让您偏离正确的轨道,而“过时”可能意味着半年或几个月前。
  • 关于node.js - nodejs/electron-forge/node-gyp : Could not find any Visual Studio installation to use after trying all the tips I could find online,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63627716/

    相关文章:

    node.js - 无法在 Ubuntu Server 16.04 上升级 NPM

    node.js - 找不到 CodeDeploy PM2 命令

    node.js - AngularJS 应用程序在本地和 Heroku 上有不同的行为

    javascript - 使用 JavaScript (Node.js) 验证 TimeUuid

    c# - 致命信号 6 (SIGABRT),tid 13929 (.AppTest.Project1) 中的代码 -6 (SI_TKILL),pid 13929 (.AppTest.Project1)

    visual-studio - 在 C :\Program Files (x86)\Microsoft SDKs\TypeScript\1. 8\tsc.exe 找不到 TypeScript 编译器

    node.js - NPM:在 OS X El Capitan 上的 "ld: library not found for -lgcc_s.10.5"?

    node.js - 与 websocket 服务器库的 Passport session

    node.js - 在 Heroku 上使用 TypeScript 和 React 应用程序托管 Express 时出现的问题

    c++ - 由于 WTTlog.DLL 导致的运行时错误?