在这个简单的应用程序中,两个不同的文件foo.js和bar.js导入Logger.js创建了一个bunyan子记录器。
问题: foo.js工作完美,但bar.js在. 这似乎是由于相对路径被固定,而和驻留在相对于项目根目录的不同目录级别。MyService.logLogger.jsMyService.logfoo.jsbar.js
bunyan创建子记录器的更好方法是什么?
.
├── lib
| └── Logger.js
├── foo
| └── foo.js
├── bar.js
/src/lib/Logger.js
const bunyan = require('bunyan')
const logger = bunyan.createLogger({
name: 'MyService',
streams: [
{
stream: process.stdout,
level: "info"
},
{
type: 'rotating-file',
path: '../logs/MyService.log',
period: '1w',
count: 100,
level: "debug"
}
]
})
module.exports = {
getChildLogger(componentName) {
return logger.child({
component: componentName
})
}
}
/src/foo/foo.js
const log = require('../lib/Logger').getChildLogger('foo')
log.info('Foo')
/src/bar.js
const log = require('./lib/Logger').getChildLogger('foo')
log.info('Bar')