A bunyan stream to send logs through to logzio.
When configuring bunyan-logzio as a stream for bunyan, you need to pass in a logzio logger.
For example:
var logzioLogger = logzio.createLogger({
protocol: 'https',
token: config.get('logzio.token'),
type: config.get('logzio.type.events')
});
Please note: auth values are NOT required to simply send logs through to logzio.
This is a basic usage example.
var bunyan = require('bunyan'),
Bunyan2Logzio = require('bunyan-logzio').Bunyan2Logzio,
logger;
// create the logger
logger = bunyan.createLogger({
name: 'logziolog',
streams: [
{
type: 'raw',
stream: new Bunyan2Logzio(logzioLogger)
}
]
});
logger.info({});
Please note: you MUST define
type: 'raw'
as bunyan-logzio expects to recieve objects so that certain values can be changed as required by logzio (i.e. time to timestamp).
This is an example of using bunyan-logzio to store express.js request logs.
var path = require('path'),
bunyan = require('bunyan'),
serializerRequest = require('../lib/serializer-request'),
Bunyan2Logzio = require('bunyan-logzio').Bunyan2Logzio,
request;
// create the logger
request = bunyan.createLogger({
name: 'request',
serializers: { req: bunyan.stdSerializers.req },
streams: [
{
type: 'raw',
stream: new Bunyan2Logzio(logzioLogger)
}
]
});
// export the middleware
module.exports = function () {
return function (req, res, next) {
// move on straight away
next();
// log this request
request.info({
req : req,
production: process.env.NODE_ENV === 'production'
});
}
}