fluent-plugin-cloudwatch-transform is an output plug-in for Fluentd
It can transform the alerts from fluent-plugin-cloudwatch to key-value pairs as "event_name" and "value", also add more information from the tag you added in fluent-plugin-cloudwatch. You can configure the position of these information in the tag, and also the name in the final output.
It also used "highwatermark" gem to store status timestamp to state file or redis cache
These instructions assume you already have fluentd installed. If you don't, please run through [quick start for fluentd] (https://github.com/fluent/fluentd#quick-start)
Now after you have fluentd installed you can follow either of the steps below:
Add this line to your application's Gemfile:
$ gem 'fluent-plugin-cloudwatch-transform'
Or install it yourself as:
$ gem install fluent-plugin-cloudwatch-transform
or
$ fluent-gem install fluent-plugin-cloudwatch-transform
//for build the gem locally:
just download or clone this repository
in the folder of this repository:
$ gem build fluent-plugin-cloudwatch-transform.gemspec
$ sudo gem install ./fluent-plugin-cloudwatch-transform-0.0.5.gem
require fluent-plugin-cloudwatch for input. require highwatermark to store timestamp to file or redis Add the following into your fluentd config.
<source>
type cloudwatch
tag #tag with some extra information that your want to put in th output after transform
# like region and availability zone, application name, wiki url in sequence
# for example: alert.raw.cloudwatch.region1-AZ1.Form & Printing Services (FPS)."http://runbook.wiki.com"
# the prefix alert.raw.cloudwatch is for the match, the rest is for the information
aws_key_id #your id
aws_sec_key #your key
cw_endpoint #your endpoint
interval #frequency to pull data
namespace #AWS namepace
metric_name #selected metric name, like: HealthyHostCount
dimensions_name #dimensions name
dimensions_value # dimensions value
</source>
<match alert.raw.cloudwatch.**>
type cloudwatch_transform
out_tag alert.processed.cloudwatch
state_type file #could be <redis/file/memory>
state_file /path/to/state/file/or/redis/conf # the file path for store state or the redis configure
state_tag cloudwatch
name_for_origin_key event_name
name_for_origin_value value
<tag_infos>
region_and_AZ 3
application_name 4
runbook 5
</tag_infos>
</match>
<match alert.processed.cloudwatch>
type stdout
</match>
Example of redis.conf (if set state_type = 'redis'):
# redis configure
host: 127.0.0.1
port: 6379
{
"HealthyHostCount": 6
}
{
"event_name": "HealthyHostCount",
"value": "6.0",
"raw": {
"HealthyHostCount": 6
},
"receive_time_input": "1426189324",
"application_name": "Form & Printing Services (FPS)",
"intermediary_source": "region1-AZ1",
"runbook": "http://runbook.wiki.com"
"event_type" : "alert.cloudwatch"
"tag": "alert.cloudwatch.out"
}
need to write the test