Skip to content

good-kinesis-reporter is a good-compatible write stream which sends events to AWS Kinesis and AWS Kinesis Firehose.

License

Notifications You must be signed in to change notification settings

vvondra/good-kinesis-reporter

Repository files navigation

good-kinesis-reporter

Kinesis and Kinesis firehose stream for good by hapi

Current Version Build Status

Usage

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.

Example

// 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();

Using as a write stream without good and available options

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.

License

MIT

About

good-kinesis-reporter is a good-compatible write stream which sends events to AWS Kinesis and AWS Kinesis Firehose.

Resources

License

Stars

Watchers

Forks

Packages

No packages published