突然在我的一个jenkins环境构建已经开始失败,而在本地机器,它似乎工作得很好,因为我有python安装,

从日志中,我能够检测到问题是内部依赖关系,即node-gyp v3.5.0从node-sass v3.8.0,当我通过访问这篇关于node-gyp的文章进行研究时,我发现了Python需要安装的先决条件。

所以我的问题是,我可以安装哪个版本的node-sass来绕过这个,或者有更好的解决方案,因为我的构建在相同的环境上运行良好,直到今天早上。

节点v5.10.1

错误日志

gyp verb check python checking for Python executable "python2" in the PATH
gyp verb `which` failed Error: not found: python2
gyp verb `which` failed     at getNotFoundError (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:13:12)
gyp verb `which` failed     at F (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:68:19)
gyp verb `which` failed     at E (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:80:29)
gyp verb `which` failed     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:89:16
gyp verb `which` failed     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\isexe\index.js:44:5
gyp verb `which` failed     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\isexe\windows.js:29:5
gyp verb `which` failed     at FSReqWrap.oncomplete (fs.js:82:15)
gyp verb `which` failed  python2 { [Error: not found: python2] code: 'ENOENT' }
gyp verb check python checking for Python executable "python" in the PATH
gyp verb `which` failed Error: not found: python
gyp verb `which` failed     at getNotFoundError (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:13:12)
gyp verb `which` failed     at F (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:68:19)
gyp verb `which` failed     at E (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:80:29)
gyp verb `which` failed     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\which\which.js:89:16
gyp verb `which` failed     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\isexe\index.js:44:5
gyp verb `which` failed     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\isexe\windows.js:29:5
gyp verb `which` failed     at FSReqWrap.oncomplete (fs.js:82:15)
gyp verb `which` failed  python { [Error: not found: python] code: 'ENOENT' }
gyp verb could not find "python". checking python launcher 
gyp verb could not find "python". guessing location 
gyp verb ensuring that file exists: C:\Python27\python.exe
gyp ERR! configure error 
gyp ERR! stack Error: Can't find Python executable "python", you can set the PYTHON env variable.
gyp ERR! stack     at Object.failNoPython (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\node-gyp\lib\configure.js:454:19)
gyp ERR! stack     at Object.<anonymous> (C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\node-gyp\lib\configure.js:480:16)
gyp ERR! stack     at C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\graceful-fs\polyfills.js:284:29
gyp ERR! stack     at FSReqWrap.oncomplete (fs.js:82:15)
gyp ERR! System Windows_NT 6.3.9600
gyp ERR! command "C:\\Program Files\\nodejs\\node.exe" "C:\\Program Files (x86)\\Jenkins\\jobs\\NdbSite-hot-fix-Manual-PreBuild\\workspace\\src\\NdbSite.UI\\node_modules\\node-gyp\\bin\\node-gyp.js" "rebuild" "--verbose" "--libsass_ext=" "--libsass_cflags=" "--libsass_ldflags=" "--libsass_library="
gyp ERR! cwd C:\Program Files (x86)\Jenkins\jobs\NdbSite-hot-fix-Manual-PreBuild\workspace\src\NdbSite.UI\node_modules\node-sass
gyp ERR! node -v v5.10.1
gyp ERR! node-gyp -v v3.5.0
gyp ERR! not ok 
Build failed

任何想法都非常感激,谢谢。


当前回答

我在Windows 10上的Node 12.19.0和yarn 1.22.5中发现了同样的问题。我通过安装最新的稳定64位python并在python安装期间将路径添加到环境变量来解决这个问题。在安装python之后,我重启了我的机器以获取env vars。

其他回答

我们在2021年设置一个新的TeamCity构建代理时遇到了这个问题。最初我们使用Chocolatey安装了nodejs。我们重新安装回到原来的安装节点-v12.12.0-x64.msi。安装程序对话框中的第三个屏幕提供了安装编译本机模块所需的工具:

这样做之后,我们的问题就解决了。

最近我在Windows上遇到了这样的情况。我通过以下步骤修复它使用一个具有管理权限的PowerShell:

删除node_modulesfolder 使用管理权限运行NPM install——global windows-build-tools。(在我的情况下需要重启-和重启没有问!!) 使用NPM install重新安装节点模块或node-sass

node-sass已于2020年10月26日弃用

不需要安装旧版本的Python,只需迁移到dart.sass即可

对于我的ReactJS项目(npm),以下步骤对我有效:

从项目中删除node_modules 在包中。Json,删除这个 依赖: “依赖”:{ …, :“node-sass ^ 3.0.0”, ... } NPM install——save-dev sass npm安装 现在尝试使用npm start运行你的项目 如果你收到一个类似于"To import Sass files, you first need To install node-sass"的错误,执行如下命令: NPM安装node-sass@npm:sass

如果你正在使用yarn,执行相同的命令,但在最后一步执行这个命令,如下所述: 纱线拆卸节点 纱加纱


下面是帮助我防止在运行基于旧node-gyp v3.8.0的项目时出现错误error: not found: python2的方法。

运行npm install——global——production windows-build-tools@4.0.0 将python.exe重命名为%USERPROFILE%\.windows-build-tools\python27中的python2.exe 确保%USERPROFILE%\。windows-build-tools\python27是PATH环境变量的一部分(这是windows-build-tools应该已经为你做的) 下载Visual Studio 2017构建工具 告诉npm使用VS 2017, npm配置msvs_version 2017 运行使用node-gyp的脚本(node-gyp现在会找到python2.exe)

可选:强制升级node-gyp

您还可以尝试将项目升级为使用node-gyp v8.0.0而不是node-gyp v3.8.0。在这种情况下,在package.json中添加以下决议项:

  "resolutions": {
    "node-gyp": "8.0.0"
  }

之后,确保安装了Python 3和Visual Studio 2017构建工具和/或Visual Studio 2019构建工具。你也可以执行npm config delete msvs_version命令让node-gyp自动检测你的VS版本。

测试:

Windows 10 Pro Build 19042.985 node . js v15.14.0 npm v7.7.6 Node-gyp -v v3.8.0。

上面的答案没有一个能解决我的问题,它比我想象的要简单得多。

只需降低您的节点版本,以匹配node-sass版本:

nvm list
nvm user <node-version>