express middleware that implements bunyan as a logger to be used with req.log
const logger = require('express-mw-bunyan')
logger(
bunyan createLogger object[,
origin = default 'request'][,
headerName = default 'X-Request-ID']
)
for more options to configure bunyan.createLogger
check with bunyan
Notes:
- should use a middleware like
express-mw-correlation-id
to generate thereq.id
if notexpress-mw-bunyan
will generate thereq.id
itself by usinguuid.v4
- if you want to set a different
headerName
but still use the defaultorigin
you should passundefined
in theorigin
place - by default Bunyan intentionally do not include the request/response
body
if you want to include that you need to change thereq
andres
serializers
const express = require('express')
const bunyan = require('bunyan')
// instead of using `express-mw-correlation-id` can use the internal uuid
// {now}:{hostname}:{pid}:{conn creation(aprox.) base36}:{8 digit counter}
const setRequestId = require('express-mw-correlation-id')
// to capture the body/payload
const bodyParser = require('body-parser')
const logger = require('express-mw-bunyan')
// middlewares
app.use(bodyParser.json())
app.use(setRequestId())
app.use(logger(bunyan.createLogger({ name: 'test' })), 'request_from_my_code')
// `req.log` will be exposed with all log methods from bunyan
app.get('/', (req, res) => {
req.log.info('getting Hello World')
res.send('Hello World')
})
app.post('/', (req, res) => {
req.log.info('Posting something')
res.status(201).send()
})
app.listen(3000)
example of the initial request
{
"name": "test",
"hostname": "m-quim.local",
"pid": 2695,
"origin": "request_from_my_code",
"req_id": "825efe65-a27d-4dca-936b-e74249095fb7",// REQUEST ID
"level": 30,
"req": {
"method": "POST",
"url": "/",
"headers": {
"host": "127.0.0.1:63135",
"accept-encoding": "gzip, deflate",
"user-agent": "node-superagent/2.3.0",
"content-type": "application/json",
"content-length": "7",
"connection": "close"
},
"remoteAddress": "::ffff:127.0.0.1",
"remotePort": 63136
},
"msg": "start of the request",
"time": "2016-12-10T13:22:56.639Z",
"v": 0
}
example of the end reponse
{
"name": "test",
"hostname": "m-quim.local",
"pid": 2695,
"origin": "request_from_my_code",
"req_id": "825efe65-a27d-4dca-936b-e74249095fb7",// REQUEST ID
"level": 30,
"res": {
"statusCode": 201,
"header": "HTTP/1.1 201 Created\r\nX-Powered-By: Express\r\nX-Request-ID: 1481376176639:127.0.0.1:2695:iwj94lbz:10000002\r\nDate: Sat, 10 Dec 2016 13:22:56 GMT\r\nConnection: close\r\nContent-Length: 0\r\n\r\n"
},
"duration": 1.337593,// DURATION APROX. OF THE OPERATION IN MS
"msg": "end of the response",
"time": "2016-12-10T13:22:56.640Z",
"v": 0
}