1
0
mirror of https://github.com/krislamo/puppet-fluentd synced 2024-11-09 20:50:34 +00:00
Generic Puppet module to manage Fluentd
Go to file
2015-12-01 17:18:07 +01:00
examples initial commit 2015-11-30 12:23:28 +01:00
files added fluentd::config 2015-11-30 17:17:54 +01:00
manifests fail if fluentd::config::file gets called from external 2015-12-01 15:29:53 +01:00
spec initial commit 2015-11-30 12:23:28 +01:00
templates added fluentd::match definition 2015-12-01 14:19:18 +01:00
.gitignore initial commit 2015-11-30 12:23:28 +01:00
Gemfile initial commit 2015-11-30 12:23:28 +01:00
metadata.json added fluentd::repo & fluentd::repo::apt 2015-11-30 15:18:26 +01:00
Rakefile initial commit 2015-11-30 12:23:28 +01:00
README.md first README draft 2015-12-01 17:18:07 +01:00

wywygmbh/fluentd Puppet Module

Table of Contents

  1. Description
  2. Setup - The basics of getting started with fluentd
  3. Usage
  1. Limitations - OS compatibility, etc.
  2. Development - Guide for contributing to the module

Description

The fluentd module sets up fluentd (td-agent) and manages configuration files.

This module only supports fluentd from version 2.

Setup

This will install the latest version of fluentd

include '::fluentd'

Usage

By default this module doesn't configure any sources, matches or filters. The section below describes how to configure these.

Configuration

Source

::fluentd::source { 'test':
  priority => 10,
  config   => {
    'type'           => 'tail'
    'format'         => 'json'
    'path'           => '/var/log/test-application/*.json'
    'tag'            => 'application.test'
  }
}

results in:

/etc/td-agent/conf.d/10-source-test.conf
<source>
    type tail
    format json
    path /var/log/test-application/*.json
    tag application.test
</source>

Filter

::fluentd::filter { 'test':
  priority => 20,
  pattern  => '*.test'
  config   => {
    'type'   => 'record_transformer'
    'record' => {
      'hostname' => '${hostname}'
    }
  }
}

results in:

/etc/td-agent/conf.d/20-filter-test.conf
<filter *.test>
        type record_transformer
        <record>
            hostname ${hostname}
        </record>
</filter>

Match

::fluentd::match { 'test':
  priority => 30,
  pattern  => '*.test'
  config   => {
    'flush_interval' => '30s'
    'type'           => 'secure_forward'
    'secure'         => 'yes'
    'shared_key'     => 'my_shared_key'
    'self_hostname'  => 'instance.test.com'
    'ca_cert_path'   => '/path/to/ca.cert'
    'servers'        => {
      'host' => 'test.server.com'
    }
  }
}

results in:

/etc/td-agent/conf.d/30-match-test.conf
<match *.test>
        flush_interval 30s
        type secure_forward
        secure yes
        shared_key my_shared_key
        self_hostname instance.test.com
        ca_cert_path /path/to/ca.cert
        <servers>
            host test.server.com
        </servers>
</match>

Limitations

This module has been built on and tested against Puppet 3.7.5 and higher.

The module has been tested on:

  • Ubuntu 12.04

Testing on other platforms has been light and cannot be guaranteed.

Development