nodejsでESモジュールを使用しているときにPM2がクラッシュする

Aug 18 2020

pacakage.jsonこのキーと値のペアでESモジュールを有効に"type": "module"しましたが、最新バージョンのノードで「実験的」フラグを使用する必要はありません。

pm2 start app.js --watchアプリを実行すると、エラーメッセージが表示されてクラッシュします

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

アプリはpm2がなくても完全に正常に動作します。pm2はまだESMをサポートしていないと推測しています!

回避策はありますか、それともいくつかの構成がありませんか?

回答

1 r7r Aug 28 2020 at 19:36

Windows10を使用している場合

pm2がWindows10でesmを使用して機能しない場合、回避策はありません。

Dipten Aug 27 2020 at 20:03

調和をノード引数として渡すようにしてください。これにより、pm2プロセスでes6機能が有効になります。

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