web-dev-qa-db-fra.com

l'application du nœud ne s'exécute pas sur mojave: ReferenceError: internalBinding n'est pas défini

J'ai essayé d'exécuter sans succès une application de noeud, qui fonctionne correctement sur High Sierra et Windows 10, mais échoue sous Mojave 10.14.1 . C'est l'erreur affichée lors de l'exécution de la tâche gulp build_dev:

[23:44:42] Requiring external module babel-register
fs.js:25
'use strict';
^

ReferenceError: internalBinding is not defined
    at fs.js:25:1
    at req_ (/Users/user1/Documents/NodeProjects/myapp/node_modules/natives/index.js:137:5)
    at Object.req [as require] (/Users/user1/Documents/NodeProjects/myapp/node_modules/natives/index.js:54:10)
    at Object.<anonymous> (/Users/user1/Documents/NodeProjects/myapp/node_modules/vinyl-fs/node_modules/graceful-fs/fs.js:1:37)
    at Module._compile (internal/modules/cjs/loader.js:707:30)
    at Module._extensions..js (internal/modules/cjs/loader.js:718:10)
    at Object.require.extensions.(anonymous function) [as .js] (/Users/user1/Documents/NodeProjects/myapp/node_modules/babel-register/lib/node.js:152:7)
    at Module.load (internal/modules/cjs/loader.js:605:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:544:12)
    at Function.Module._load (internal/modules/cjs/loader.js:536:3)
npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! [email protected] dev: `node node_modules/gulp/bin/gulp.js build_dev`
npm ERR! Exit status 1
npm ERR! 
npm ERR! Failed at the [email protected] dev 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/user1/.npm/_logs/2018-11-04T22_44_42_709Z-debug.log

Voici le contenu du fichier package.json avec toutes les dépendances utilisées dans l'application:

{
  "name": "myapp",
  "version": "1.0.0",
  "description": "",
  "main": "server.js",
  "scripts": {
    "test-dev": "node node_modules/gulp/bin/gulp.js test_dev",
    "test-prod": "node node_modules/gulp/bin/gulp.js test_prod",
    "dev": "node node_modules/gulp/bin/gulp.js build_dev",
    "prod": "node node_modules/gulp/bin/gulp.js build_prod"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "babel-polyfill": "^6.26.0",
    "body-parser": "^1.17.2",
    "cookie-parser": "^1.4.3",
    "envify": "^4.1.0",
    "express": "^4.16.2",
    "glob": "^7.1.2",
    "http-status-codes": "^1.1.6",
    "morgan": "^1.8.2",
    "multi-glob": "^1.0.1",
    "npm": "^6.4.1",
    "path": "^0.12.7"
  },
  "devDependencies": {
    "babel-cli": "^6.24.1",
    "babel-core": "^6.26.0",
    "babel-plugin-syntax-async-functions": "^6.13.0",
    "babel-plugin-transform-async-to-generator": "^6.24.1",
    "babel-preset-env": "^1.6.0",
    "babel-register": "^6.24.1",
    "babelify": "^7.3.0",
    "browser-sync": "^2.26.3",
    "browserify": "^16.1.0",
    "gulp": "^3.9.1",
    "gulp-concat": "^2.6.1",
    "gulp-if": "^2.0.2",
    "gulp-imagemin": "^3.3.0",
    "gulp-minify-css": "^1.2.4",
    "gulp-nodemon": "^2.2.1",
    "gulp-notify": "^3.0.0",
    "gulp-rename": "^1.2.2",
    "gulp-sass": "^3.1.0",
    "gulp-sass-glob": "^1.0.8",
    "gulp-sourcemaps": "^2.6.0",
    "gulp-uglify": "^3.0.0",
    "gulp-util": "^3.0.8",
    "imagemin-pngquant": "^5.0.1",
    "run-sequence": "^2.2.0",
    "vinyl-buffer": "^1.0.0",
    "vinyl-source-stream": "^1.1.0"
  }
}

Toute astuce sur la façon de déboguer ce problème? Pourrait être lié à la version du compilateur gcc?

version du noeud: 11.1.0 npm version: 6.4.1

Sur ce lien, j'ai téléchargé le journal de la commande "npm install" pour installer les dépendances: npm_install.log

9
revy

Essayez de mettre à jour natives vers la dernière version. Ceci commit semble résoudre le problème que vous rencontrez.

15
Primož Hadalin

J'ai abaissé la version du noeud de 10.15.0 (LTS) à 10.10.0. Et cette erreur internalBinding fixe pour moi.

Sudo npm cache clean -f
Sudo npm install -g n
Sudo n 10.10.0
3
Ihor Khomiak

Dans mon cas, le problème concernait l'installation de node_modules. Procédez comme suit.

  • Effectuer un yarn audit
  • Vérifiez si vous avez des vulnérabilités critiques
  • Mettez à niveau la version du module ou recherchez un autre module.
  • yarn install
  • Vous devriez être bon pour aller

Remarque: le problème ne concernait pas la version du noeud. Dans mon cas, il s'agissait simplement d'un module vulnérable (gulp-angular-templatecache). Je vous suggère également de faire npm upgrade et npm rebuild si la méthode ci-dessus ne fonctionne pas.

npm audit ne fonctionne pas avec les référentiels privés mais yarn audit le fait.

0
Santosh