PM2 se bloquea al usar módulos ES en nodejs

Aug 18 2020

He habilitado los módulos ES pacakage.jsoncon este par de valores clave, "type": "module"no tengo que usar el indicador 'experimental' con la última versión del nodo

cuando ejecuto pm2 start app.js --watchla aplicación se bloquea con el mensaje de error

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    | }

la aplicación funciona perfectamente bien sin pm2. ¡Supongo que pm2 aún no es compatible con ESM!

¿alguna solución o me faltan algunas configuraciones?

Respuestas

1 r7r Aug 28 2020 at 19:36

Si estás en Windows 10

pm2 no funciona con esm en Windows 10, ¡no hay soluciones!

Dipten Aug 27 2020 at 20:03

Intente pasar la armonía como argumentos de nodo, ya que habilitará las funciones es6 en el proceso pm2.

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