PM2 si arresta in modo anomalo durante l'utilizzo dei moduli ES in nodejs

Aug 18 2020

Ho abilitato i moduli ES pacakage.jsoncon questa coppia chiave-valore "type": "module"non devo usare il flag 'sperimentale' con l'ultima versione del nodo

quando eseguo pm2 start app.js --watchl'app si blocca con il messaggio di errore

0|app    | Error [ERR_UNSUPPORTED_ESM_URL_SCHEME]: Only file and data URLs are supported by the default ESM loader
0|app    |     at Loader.defaultResolve [as _resolve] (internal/modules/esm/resolve.js:781:11)
0|app    |     at Loader.resolve (internal/modules/esm/loader.js:85:40)
0|app    |     at Loader.getModuleJob (internal/modules/esm/loader.js:229:28)
0|app    |     at Loader.import (internal/modules/esm/loader.js:164:28)
0|app    |     at importModuleDynamically (internal/modules/cjs/loader.js:1194:27)
0|app    |     at exports.importModuleDynamicallyCallback (internal/process/esm_loader.js:30:14)
0|app    |     at Object.<anonymous> (C:\Users\username\AppData\Roaming\npm\node_modules\pm2\lib\ProcessContainerFork.js:29:24)
0|app    |     at Module._compile (internal/modules/cjs/loader.js:1251:30)
0|app    |     at Object.Module._extensions..js (internal/modules/cjs/loader.js:1272:10)
0|app    |     at Module.load (internal/modules/cjs/loader.js:1100:32) {
0|app    |   code: 'ERR_UNSUPPORTED_ESM_URL_SCHEME'
0|app    | }

l'app funziona perfettamente senza pm2. immagino che pm2 non supporti ancora ESM!

eventuali soluzioni alternative o mi mancano alcune configurazioni?

Risposte

1 r7r Aug 28 2020 at 19:36

Se sei su Windows 10

pm2 non funziona con esm su Windows 10, non ci sono soluzioni alternative!

Dipten Aug 27 2020 at 20:03

Prova a passare l'armonia come argomenti del nodo in quanto abiliterà le funzionalità es6 nel processo pm2.

pm2 start my_app.js --watch --node-args="--harmony"