当前位置:   article > 正文

自动化部署npm安装sass是报错,往往是node版本太高导致的_command sh -c node scripts/build.js

command sh -c node scripts/build.js

本想尝试一下github的自动化部署,将一个vue项目部署到github pages上面,结果报错:

报错: 

npm ERR! code 1

50npm ERR! path /home/runner/work/CvReport/CvReport/node_modules/node-sass

51npm ERR! command failed

52npm ERR! command sh -c -- node scripts/build.js

53npm ERR! Building: /usr/local/bin/node /home/runner/work/CvReport/CvReport/node_modules/node-gyp/bin/node-gyp.js rebuild --verbose --libsass_ext= --libsass_cflags= --libsass_ldflags= --libsass_library=

54npm ERR! gyp info it worked if it ends with ok

55npm ERR! gyp verb cli [

56npm ERR! gyp verb cli '/usr/local/bin/node',

57npm ERR! gyp verb cli '/home/runner/work/CvReport/CvReport/node_modules/node-gyp/bin/node-gyp.js',

58npm ERR! gyp verb cli 'rebuild',

59npm ERR! gyp verb cli '--verbose',

60npm ERR! gyp verb cli '--libsass_ext=',

61npm ERR! gyp verb cli '--libsass_cflags=',

62npm ERR! gyp verb cli '--libsass_ldflags=',

63npm ERR! gyp verb cli '--libsass_library='

64npm ERR! gyp verb cli ]

65npm ERR! gyp info using node-gyp@3.8.0

66npm ERR! gyp info using node@16.18.1 | linux | x64

67npm ERR! gyp verb command rebuild []

68npm ERR! gyp verb command clean []

69npm ERR! gyp verb clean removing "build" directory

70npm ERR! gyp verb command configure []

71npm ERR! gyp verb check python checking for Python executable "python2" in the PATH

72npm ERR! gyp verb `which` failed Error: not found: python2

73npm ERR! gyp verb `which` failed at getNotFoundError (/home/runner/work/CvReport/CvReport/node_modules/which/which.js:13:12)

74npm ERR! gyp verb `which` failed at F (/home/runner/work/CvReport/CvReport/node_modules/which/which.js:68:19)

75npm ERR! gyp verb `which` failed at E (/home/runner/work/CvReport/CvReport/node_modules/which/which.js:80:29)

76npm ERR! gyp verb `which` failed at /home/runner/work/CvReport/CvReport/node_modules/which/which.js:89:16

77npm ERR! gyp verb `which` failed at /home/runner/work/CvReport/CvReport/node_modules/isexe/index.js:42:5

78npm ERR! gyp verb `which` failed at /home/runner/work/CvReport/CvReport/node_modules/isexe/mode.js:8:5

79npm ERR! gyp verb `which` failed at FSReqCallback.oncomplete (node:fs:202:21)

80npm ERR! gyp verb `which` failed python2 Error: not found: python2

81npm ERR! gyp verb `which` failed at getNotFoundError (/home/runner/work/CvReport/CvReport/node_modules/which/which.js:13:12)

82npm ERR! gyp verb `which` failed at F (/home/runner/work/CvReport/CvReport/node_modules/which/which.js:68:19)

83npm ERR! gyp verb `which` failed at E (/home/runner/work/CvReport/CvReport/node_modules/which/which.js:80:29)

84npm ERR! gyp verb `which` failed at /home/runner/work/CvReport/CvReport/node_modules/which/which.js:89:16

85npm ERR! gyp verb `which` failed at /home/runner/work/CvReport/CvReport/node_modules/isexe/index.js:42:5

86npm ERR! gyp verb `which` failed at /home/runner/work/CvReport/CvReport/node_modules/isexe/mode.js:8:5

87npm ERR! gyp verb `which` failed at FSReqCallback.oncomplete (node:fs:202:21) {

88npm ERR! gyp verb `which` failed code: 'ENOENT'

89npm ERR! gyp verb `which` failed }

90npm ERR! gyp verb check python checking for Python executable "python" in the PATH

91npm ERR! gyp verb `which` succeeded python /usr/bin/python

92npm ERR! gyp ERR! configure error

93npm ERR! gyp ERR! stack Error: Command failed: /usr/bin/python -c import sys; print "%s.%s.%s" % sys.version_info[:3];

94npm ERR! gyp ERR! stack File "<string>", line 1

95npm ERR! gyp ERR! stack import sys; print "%s.%s.%s" % sys.version_info[:3];

96npm ERR! gyp ERR! stack ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

97npm ERR! gyp ERR! stack SyntaxError: Missing parentheses in call to 'print'. Did you mean print(...)?

98npm ERR! gyp ERR! stack

99npm ERR! gyp ERR! stack at ChildProcess.exithandler (node:child_process:402:12)

100npm ERR! gyp ERR! stack at ChildProcess.emit (node:events:513:28)

101npm ERR! gyp ERR! stack at maybeClose (node:internal/child_process:1100:16)

102npm ERR! gyp ERR! stack at Socket.<anonymous> (node:internal/child_process:458:11)

103npm ERR! gyp ERR! stack at Socket.emit (node:events:513:28)

104npm ERR! gyp ERR! stack at Pipe.<anonymous> (node:net:301:12)

105npm ERR! gyp ERR! System Linux 5.15.0-1024-azure

106npm ERR! gyp ERR! command "/usr/local/bin/node" "/home/runner/work/CvReport/CvReport/node_modules/node-gyp/bin/node-gyp.js" "rebuild" "--verbose" "--libsass_ext=" "--libsass_cflags=" "--libsass_ldflags=" "--libsass_library="

107npm ERR! gyp ERR! cwd /home/runner/work/CvReport/CvReport/node_modules/node-sass

108npm ERR! gyp ERR! node -v v16.18.1

109npm ERR! gyp ERR! node-gyp -v v3.8.0

110npm ERR! gyp ERR! not ok

111npm ERR! Build failed with error code: 1

112

113npm ERR! A complete log of this run can be found in:

114npm ERR! /home/runner/.npm/_logs/2022-12-13T06_06_26_664Z-debug-0.log

115Error: Process completed with exit code 1.

原因:node版本太高导致的,我本地开发用的是14.18.3,但是使用github action部署的时候,如果不指定默认的,就会用最新版的,所以就导致了不成功,需要指定和本地版本差不多的版本,或者指定多个版本:

  1. name: Node.js CI
  2. on:
  3. push:
  4. branches: [ main ]
  5. pull_request:
  6. branches: [ main ]
  7. jobs:
  8. build:
  9. runs-on: ubuntu-latest
  10. strategy:
  11. matrix:
  12. node-version: [10.x, 12.x, 14.x, 15.x]
  13. steps:
  14. - uses: actions/checkout@v3
  15. - name: Use Node.js ${{ matrix.node-version }}
  16. uses: actions/setup-node@v3
  17. with:
  18. node-version: ${{ matrix.node-version }}
  19. - run: npm ci
  20. - run: npm run build --if-present
  21. - run: npm test

您也可以使用单个版本的 Node.js 构建和测试:

  1. name: Node.js CI
  2. on: [push]
  3. jobs:
  4. build:
  5. runs-on: ubuntu-latest
  6. steps:
  7. - uses: actions/checkout@v3
  8. - name: Use Node.js
  9. uses: actions/setup-node@v3
  10. with:
  11. node-version: '12.x'
  12. - run: npm ci
  13. - run: npm run build --if-present
  14. - run: npm test

 就会成功了:看吧,14成功了,15就失败

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/82133
推荐阅读
相关标签
  

闽ICP备14008679号