No release in over 3 years
Low commit activity in last 3 years
Fluentd plugin to fetch record by input data, and to emit the record data.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.14
~> 12.0
~> 3.0

Runtime

< 2, >= 0.14.10
>= 0
 Project Readme

fluent-plugin-mysql-fetch-and-emit

CircleCI

Fluentd output plugin to fetch from mysql by fluentd record and re-emit fetched record.

Installation

RubyGems

$ gem install fluent-plugin-mysql-fetch-and-emit

Bundler

Add following line to your Gemfile:

gem "fluent-plugin-mysql-fetch-and-emit"

And then execute:

$ bundle

Example

<match tag>
  @type mysql_fetch_and_emit

  host 127.0.0.1
  username root
  password password
  database db
  table users

  record_key id

  tag new_tag
</match>

<match new_tag>
  @type stdout
</match>

Record Matching

<match tag>
  @type mysql_fetch_and_emit

  host 127.0.0.1
  username root
  password password
  database db
  table users

  record_key id

  tag new_tag

  <record_matching_key>
    fluentd_record_key email
    mysql_record_key email
  </record_matching_key>
</match>

<match new_tag>
  @type stdout
</match>

If fluentd record has email and match email value of mysql record, plugin merges them. You can set priority of merged records by merge_priority.

If remove_keys has some values, plugin remove key from fluentd record before merging.

Plugin helpers

Configuration

host (string) (optional)

Database host.

Default value: 127.0.0.1.

port (integer) (optional)

Database port.

Default value: 3306.

database (string) (required)

Database name.

username (string) (required)

Database user.

password (string) (optional)

Database password.

Default value: ``.

sslkey (string) (optional)

SSL key.

sslcert (string) (optional)

SSL cert.

sslca (string) (optional)

SSL CA.

sslcapath (string) (optional)

SSL CA path.

sslcipher (string) (optional)

SSL cipher.

sslverify (bool) (optional)

SSL Verify Server Certificate.

cast_booleans (bool) (optional)

Tell Mysql2 to cast tinyint(1) fields to boolean values.

stream (bool) (optional)

Fetch rows from the mysql on demand.

table (string) (required)

Database table name.

tag (string) (required)

New tag.

record_key (string) (required)

Use the record value for where condition. (record_accessor format)

additional_condition (string) (optional)

Append this value to where clause.

where_column (string) (optional)

Database column name for where condition.

column_names (array) (optional)

Select column names.

Default value: ["*"].

<record_matching_key> section (optional) (multiple)

fluentd_record_key (string) (required)

Fluentd record key to identify target to merge with mysql record

mysql_record_key (string) (required)

Mysql record column name to identify target to merge with fluentd record

merge_priority (enum) (optional)

Preserve data priority. If this is set :mysql, prioritize database record data.

Available values: fluentd, mysql

Default value: fluentd.

remove_keys (array) (optional)

A list of keys to delete from fluentd record

Default value: [].

<buffer> section (optional) (multiple)

chunk_limit_records () (optional)

Default value: 1000.

Copyright

  • Copyright(c) 2018- joker1007
  • License
    • Apache License, Version 2.0