在这个简单的应用程序中,两个不同的文件foo.js
和bar.js
导入Logger.js
创建了一个bunyan
子记录器。
问题: foo.js
工作完美,但bar.js
在. 这似乎是由于相对路径被固定,而和驻留在相对于项目根目录的不同目录级别。MyService.log
Logger.js
MyService.log
foo.js
bar.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')