Kinesis and Kinesis firehose stream for good by hapi
good-kinesis-reporter
is a write stream use to send events to AWS Kinesis and AWS Kinesis Firehose.
Kinesis Firehose has become one of the preferred ways for me to transport logs from containers and servers in an AWS environment to Elasticsearch, skipping Logstash and its overhead altogether.
// server.js
const Hapi = require('hapi');
const server = Hapi.server({
port: 3000,
host: 'localhost'
});
const options = {
reporters: {
kinesis: [{
module: 'good-squeeze',
name: 'Squeeze',
args: [{ log: '*', response: '*', request: '*', server: '*' }]
}, {
module: 'good-kinesis-reporter',
name: 'Firehose', // can be either Kinesis or Firehose
args: [
{ streamName: 'my-delivery-stream' } // only streamName is mandatory, the rest are the SDK client options
]
}]
}
};
const init = async () => {
await server.register({
plugin: require('good'),
options,
});
await server.start();
console.log(`Server running at: ${server.info.uri}`);
};
process.on('unhandledRejection', (err) => {
console.log(err);
process.exit(1);
});
init();
Creates a new GoodKinesis or GoodFirehose object:
const goodkinesis = require('good-kinesis-reporter');
const kinesisStream = goodkinesis.Kinesis({ streamName: 'my-kinesis-stream' });
const firehoseStream = goodkinesis.Firehose({ streamName: 'my-firehose-stream' });
Available options:
streamName
- Stream name
All options are passed to the AWS SDK constructor
As best practice, configuring the AWS SDK client is recommended using environment variables or instance profile permissions in an EC2 context.