Class: LogStash::Codecs::Graphite

Inherits:
Base
  • Object
show all
Includes:
PluginMixins::EventSupport::EventFactoryAdapter
Defined in:
lib/logstash/codecs/graphite.rb

Overview

This codec will encode and decode Graphite formated lines.

Constant Summary collapse

EXCLUDE_ALWAYS =
[ "@timestamp", "@version" ]
DEFAULT_METRICS_FORMAT =
"*"
METRIC_PLACEHOLDER =
"*"

Instance Method Summary collapse

Constructor Details

#initialize(params = {}) ⇒ Graphite

Returns a new instance of Graphite.



50
51
52
53
# File 'lib/logstash/codecs/graphite.rb', line 50

def initialize(params={})
  super(params)
  @lines = LogStash::Codecs::Line.new
end

Instance Method Details

#decode(data) ⇒ Object



56
57
58
59
60
61
# File 'lib/logstash/codecs/graphite.rb', line 56

def decode(data)
  @lines.decode(data) do |event|
    name, value, time = event.get("message").split(" ")
    yield event_factory.new_event(name => value.to_f, LogStash::Event::TIMESTAMP => LogStash::Timestamp.at(time.to_i))
  end # @lines.decode
end

#encode(event) ⇒ Object



73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
# File 'lib/logstash/codecs/graphite.rb', line 73

def encode(event)
  # Graphite message format: metric value timestamp\n

  messages = []
  timestamp = event.sprintf("%{+%s}")
  @metrics_format = event.sprintf(@metrics_format)

  if @fields_are_metrics
    @logger.debug("got metrics event", :metrics => event.to_hash)
    event.to_hash.each do |metric,value|
      next if EXCLUDE_ALWAYS.include?(metric)
      next unless @include_metrics.empty? || @include_metrics.any? { |regexp| metric.match(regexp) }
      next if @exclude_metrics.any? {|regexp| metric.match(regexp)}
      messages << "#{construct_metric_name(metric)} #{event.sprintf(value.to_s).to_f} #{timestamp}"
    end # data.to_hash.each
  else
    @metrics.each do |metric, value|
      @logger.debug("processing", :metric => metric, :value => value)
      metric = event.sprintf(metric)
      next unless @include_metrics.any? {|regexp| metric.match(regexp)}
      next if @exclude_metrics.any? {|regexp| metric.match(regexp)}
      messages << "#{construct_metric_name(event.sprintf(metric))} #{event.sprintf(value).to_f} #{timestamp}"
    end # @metrics.each
  end # if @fields_are_metrics

  if messages.empty?
    @logger.debug("Message is empty, not emiting anything.", :messages => messages)
  else
    message = messages.join(NL) + NL
    @logger.debug("Emiting carbon messages", :messages => messages)

    @on_event.call(event, message)
  end # if messages.empty?
end