Class: Fluent::InfluxdbMetricsOutput
- Inherits:
-
BufferedOutput
- Object
- BufferedOutput
- Fluent::InfluxdbMetricsOutput
- Defined in:
- lib/fluent/plugin/out_influxdb_metrics.rb
Instance Method Summary collapse
- #configure(conf) ⇒ Object
- #filter_keys ⇒ Object
- #format(tag, time, record) ⇒ Object
- #format_record(tag, time, record) ⇒ Object
- #influx_client ⇒ Object
-
#initialize ⇒ InfluxdbMetricsOutput
constructor
A new instance of InfluxdbMetricsOutput.
- #shutdown ⇒ Object
- #start ⇒ Object
- #write(chunk) ⇒ Object
Constructor Details
#initialize ⇒ InfluxdbMetricsOutput
Returns a new instance of InfluxdbMetricsOutput.
16 17 18 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 16 def initialize super end |
Instance Method Details
#configure(conf) ⇒ Object
20 21 22 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 20 def configure(conf) super end |
#filter_keys ⇒ Object
28 29 30 31 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 28 def filter_keys @filter_keys ||= @fields.split(',').map(&:strip) @filter_keys end |
#format(tag, time, record) ⇒ Object
33 34 35 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 33 def format(tag, time, record) [tag, time, record].to_msgpack end |
#format_record(tag, time, record) ⇒ Object
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 60 def format_record(tag, time, record) metric = {time: time} filter_keys.each do |field| field_scored = field.gsub('.', '_') path = field.split('.') rec_pos = record[path.shift] path.each do |p| rec_pos = rec_pos[p] if rec_pos end if rec_pos metric[field_scored] = rec_pos end end return metric if metric.keys.length > 1 nil end |
#influx_client ⇒ Object
41 42 43 44 45 46 47 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 41 def influx_client @influxdb ||= InfluxDB::Client.new(@dbname, host: @host, port: @port, username: @user, password: @password) @influxdb end |
#shutdown ⇒ Object
37 38 39 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 37 def shutdown super end |
#start ⇒ Object
24 25 26 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 24 def start super end |
#write(chunk) ⇒ Object
49 50 51 52 53 54 55 56 57 58 |
# File 'lib/fluent/plugin/out_influxdb_metrics.rb', line 49 def write(chunk) bulk = [] chunk.msgpack_each do |tag, time, record| formatted_record = format_record(tag, time, record) bulk << formatted_record if formatted_record end influx_client.write_point(@table, bulk, false, 's') end |