webpack ベースのアプリケーションで bunyan をセットアップしようとしています。
次の webpack 構成があります。
// these shims are needed for bunyan
alias: {
'dtrace-provider': path.resolve('empty-shim.js'),
"fs": path.resolve('empty-shim.js'),
'safe-json-stringify': path.resolve('empty-shim.js'),
"mv": path.resolve('empty-shim.js'),
'source-map-support': path.resolve('empty-shim.js')
}
empty-shim は空のファイルです
そして、私のロガーで定義された次のストリーム:
{
level: "trace",
path: "/logs/trace.log"
// Logging from external libraries used by your app or very detailed application logging.
},
{
level: "debug",
path: "/logs/debug.log"
// Anything else, i.e. too verbose to be included in "info" level.
},
{
level: "info",
path: "/logs/info.log"
// Detail on regular operation.
},
{
level: "warn",
path: "/logs/warn.log"
// A note on something that should probably be looked at by an operator eventually.
},
{
level: "error",
stream: process.stderr // we pipe error also to stdout
// Fatal for a particular request, but the service/app continues
// servicing other requests. An operator should look at this soon(ish).
},
{
level: "error",
path: "/logs/error.log"
// Fatal for a particular request, but the service/app continues
// servicing other requests. An operator should look at this soon(ish).
},
{
level: "fatal",
path: "/logs/fatal.log"
// The service/app is going to stop or become unusable now.
// An operator should definitely look into this soon.
}
ロガーにアクセスしようとすると、次のエラーが発生します。
Uncaught TypeError: fs.createWriteStream is not a function
at Logger.addStream (http://localhost:8080/bundle.js:81080:28)
at http://localhost:8080/bundle.js:80958:19
at Array.forEach (native)
at new Logger (http://localhost:8080/bundle.js:80957:26)
at Function.createLogger (http://localhost:8080/bundle.js:82060:13)
at BunyanLogger.getLogger (http://localhost:8080/bundle.js:80479:18)
これは、 fs が空のファイルにシムされたことが原因だと思います。
どうすればこれを機能させることができますか?