Fluentd output plugin that sends events to Amazon Kinesis Streams and Amazon Kinesis Firehose. Also it supports KPL Aggregated record format. This gem includes three output plugins respectively:
kinesis_streams
kinesis_firehose
kinesis_streams_aggregated
Also, there is a documentation on Fluentd official site.
Note: This README is for v2.x. If you use v1.x, see the old README.
This fluentd plugin is available as the fluent-plugin-kinesis
gem from RubyGems.
gem install fluent-plugin-kinesis
Or you can install this plugin for td-agent as:
td-agent-gem install fluent-plugin-kinesis
If you would like to build by yourself and install, please see the section below. Your need bundler for this.
In case of using with Fluentd: Fluentd will be also installed via the process below.
git clone https://github.com/awslabs/aws-fluent-plugin-kinesis.git
cd aws-fluent-plugin-kinesis
bundle install
bundle exec rake build
bundle exec rake install
Also, you can use this plugin with td-agent: You have to install td-agent before installing this plugin.
git clone https://github.com/awslabs/aws-fluent-plugin-kinesis.git
cd aws-fluent-plugin-kinesis
bundle install
bundle exec rake build
fluent-gem install pkg/fluent-plugin-kinesis
Or just download specify your Ruby library path. Below is the sample for specifying your library path via RUBYLIB.
git clone https://github.com/awslabs/aws-fluent-plugin-kinesis.git
cd aws-fluent-plugin-kinesis
bundle install
export RUBYLIB=$RUBYLIB:/path/to/aws-fluent-plugin-kinesis/lib
- Ruby 2.1.0+
- Fluentd 0.14.10+
Here are general procedures for using this plugin:
- Install.
- Edit configuration
- Run Fluentd or td-agent
You can run this plugin with Fluentd as follows:
- Install.
- Edit configuration file and save it as 'fluentd.conf'.
- Then, run
fluentd -c /path/to/fluentd.conf
To run with td-agent, it would be as follows:
- Install.
- Edit configuration file provided by td-agent.
- Then, run or restart td-agent.
Assume you use Amazon EC2 instances with Instance profile. If you want to use specific credentials, see Credentials.
<match your_tag>
@type kinesis_streams
region us-east-1
stream_name your_stream
partition_key key # Otherwise, use random partition key
</match>
For more detail, see Configuration: kinesis_streams
<match your_tag>
@type kinesis_firehose
region us-east-1
delivery_stream_name your_stream
</match>
For more detail, see Configuration: kinesis_firehose
<match your_tag>
@type kinesis_streams_aggregated
region us-east-1
stream_name your_stream
# Unlike kinesis_streams, there is no way to use dynamic partition key.
# fixed_partition_key or random.
</match>
For more detail, see Configuration: kinesis_streams_aggregated
Add configuration like below:
flush_interval 1
chunk_limit_size 1m
flush_thread_interval 0.1
flush_thread_burst_interval 0.01
flush_thread_count 15
Note: Each value should be adjusted to your system by yourself.
To put records into Amazon Kinesis Streams or Firehose, you need to provide AWS security credentials somehow. Without specifiying credentials in config file, this plugin automatically fetch credential just following AWS SDK for Ruby does (environment variable, shared profile, and instance profile).
This plugin uses the same configuration in fluent-plugin-s3.
aws_key_id
AWS access key id. This parameter is required when your agent is not
running on EC2 instance with an IAM Role. When using an IAM role, make
sure to configure instance_profile_credentials
. Usage can be found below.
aws_sec_key
AWS secret key. This parameter is required when your agent is not running on EC2 instance with an IAM Role.
aws_iam_retries
The number of attempts to make (with exponential backoff) when loading instance profile credentials from the EC2 metadata service using an IAM role. Defaults to 5 retries.
Typically, you use AssumeRole for cross-account access or federation.
<match *>
@type kinesis_streams
<assume_role_credentials>
role_arn ROLE_ARN
role_session_name ROLE_SESSION_NAME
</assume_role_credentials>
</match>
See also:
role_arn (required)
The Amazon Resource Name (ARN) of the role to assume.
role_session_name (required)
An identifier for the assumed role session.
policy
An IAM policy in JSON format.
duration_seconds
The duration, in seconds, of the role session. The value can range from 900 seconds (15 minutes) to 3600 seconds (1 hour). By default, the value is set to 3600 seconds.
external_id
A unique identifier that is used by third parties when assuming roles in their customers' accounts.
sts_http_proxy
Proxy url for proxying requests to amazon sts service api. This needs to be set up independently from global http_proxy parameter for the use case in which requests to kinesis api are going via kinesis vpc endpoint but requests to sts api have to go via http proxy. It should be added to assume_role_credentials configuration stanza in the next format: sts_http_proxy http://[username:password]@hostname:port
Retrieve temporary security credentials via HTTP request. This is useful on EC2 instance.
<match *>
@type kinesis_streams
<instance_profile_credentials>
ip_address IP_ADDRESS
port PORT
</instance_profile_credentials>
</match>
See also:
- Aws::InstanceProfileCredentials
- Temporary Security Credentials - AWS Identity and Access Management
- Instance Metadata and User Data - Amazon Elastic Compute Cloud
retries
Number of times to retry when retrieving credentials. Default is 5.
ip_address
Default is 169.254.169.254.
port
Default is 80.
http_open_timeout
Default is 5.
http_read_timeout
Default is 5.
This loads AWS access credentials from local ini file. This is useful for local developing.
<match *>
@type kinesis_streams
<shared_credentials>
path PATH
profile_name PROFILE_NAME
</shared_credentials>
</match>
See also:
path
Path to the shared file. Defaults to "#{Dir.home}/.aws/credentials".
profile_name
Defaults to 'default' or [ENV]('AWS_PROFILE')
.
This plugin use Fluent::TextFormatter
to serialize record to string. For more detail, see formatter.rb. By default, it uses json
formatter same as specific like below:
<match *>
@type kinesis_streams
<format>
@type json
</format>
</match>
This plugin use Fluent::TimeFormatter
and other injection configurations. For more detail, see inject.rb. This section only works with Fluentd v0.14.
For example, the config below will add time
field whose value is eventtime with nanosecond and tag
field whose value is its tag. (Mostly same as include_time key true
and include_tag_key true
)
<match *>
@type kinesis_streams
<inject>
time_key time
tag_key tag
</inject>
</match>
By default, time_type string
and time_format %Y-%m-%dT%H:%M:%S.%N%z
are already set to be applicable to Elasticsearch subsecond format. Although, you can use any configuration.
Also, there are some format related options below:
Notice With Fluentd v0.14, you should use inject section.
Defalut false
. If you want to include time
field in your record, set true
.
Notice With Fluentd v0.14, you should use inject section.
Defalut false
. If you want to include tag
field in your record, set true
.
If your record contains a field whose string should be sent to Amazon Kinesis directly (without formatter), use this parameter to specify the field. In that case, other fileds than data_key are thrown away and never sent to Amazon Kinesis. Default nil
, which means whole record will be formatted and sent.
Specifing compression way for data of each record. Current accepted options are zlib
. Otherwise, no compression will be preformed.
Integer, default 1024. When emitting the log entry, the message will be truncated by this size to avoid infinite loop when the log is also sent to Kinesis. The value 0 means no truncation.
AWS region of your stream. It should be in form like us-east-1
, us-west-2
. Refer to Regions and Endpoints in AWS General Reference for supported regions.
Default nil
, which means try to find from environment variable AWS_REGION
.
The upper limit of size of each record. Default is 1 MB which is the limitation of Kinesis.
HTTP proxy for API calling. Default nil
.
API endpoint URL, for testing. Defalut nil
.
Boolean. Disable if you want to verify ssl conncetion, for testing. Default true
.
Boolean. Enable if you need to debug Amazon Kinesis Firehose API call. Default is false
.
Integer, default is 3. The plugin will put multiple records to Amazon Kinesis Streams in batches using PutRecords. A set of records in a batch may fail for reasons documented in the Kinesis Service API Reference for PutRecords. Failed records will be retried retries_on_batch_request times. If a record fails all retries an error log will be emitted.
Boolean, default true
. If enabled, when after retrying, the next retrying checks the number of succeeded records on the former batch request and reset exponential backoff if there is any success. Because batch request could be composed by requests across shards, simple exponential backoff for the batch request wouldn't work some cases.
Integer, default 500. The number of max count of making batch request from record chunk. It can't exceed the default value because it's API limit.
Default:
kinesis_streams
: 500kinesis_firehose
: 500kinesis_streams_aggregated
: 100,000
Integer. The number of max size of making batch request from record chunk. It can't exceed the default value because it's API limit.
Default:
kinesis_streams
: 5 MBkinesis_firehose
: 4 MBkinesis_streams_aggregated
: 1 MB
Here are kinesis_streams
specific configurations.
Name of the stream to put data.
A key to extract partition key from JSON object. Default nil
, which means partition key will be generated randomly.
Here are kinesis_firehose
specific configurations.
Name of the delivery stream to put data.
Boolean. Default true
. If it is enabled, the plugin add new line character (\n
) to each serialized record.
Here are kinesis_streams_aggregated
specific configurations.
Name of the stream to put data.
A value of fixed partition key. Default nil
, which means partition key will be generated randomly.
Note: if you specified this option, all records go to a single shard.
To launch fluentd
process with this plugin for development, follow the steps below:
git clone https://github.com/awslabs/aws-fluent-plugin-kinesis.git
cd aws-fluent-plugin-kinesis
make # will install gems dependency
bundle exec fluentd -c /path/to/fluent.conf
To launch using Fluentd v0.12, use BUNDLE_GEMFILE
environment variable:
BUNDLE_GEMFILE=$PWD/gemfiles/Gemfile.td-agent-2.3.5 bundle exec fluentd -c /path/to/fluent.conf
Bug reports and pull requests are welcome on GitHub.