Sha256: f48dd014621b8cbc3e0e56dffe91eb1504240e90c704d97bda59d53fecd5b1e3

Contents?: true

Size: 1.74 KB

Versions: 25

Compression:

Stored size: 1.74 KB

Contents

#
# Fluentd
#
#    Licensed under the Apache License, Version 2.0 (the "License");
#    you may not use this file except in compliance with the License.
#    You may obtain a copy of the License at
#
#        http://www.apache.org/licenses/LICENSE-2.0
#
#    Unless required by applicable law or agreed to in writing, software
#    distributed under the License is distributed on an "AS IS" BASIS,
#    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#    See the License for the specific language governing permissions and
#    limitations under the License.
#

require 'cool.io'

require 'fluent/input'

module Fluent
  class GCStatInput < Input
    Plugin.register_input('gc_stat', self)

    def initialize
      super
    end

    config_param :emit_interval, :time, default: 60
    config_param :tag, :string

    class TimerWatcher < Coolio::TimerWatcher
      def initialize(interval, repeat, log, &callback)
        @callback = callback
        @log = log
        super(interval, repeat)
      end

      def on_timer
        @callback.call
      rescue
        # TODO log?
        @log.error $!.to_s
        @log.error_backtrace
      end
    end

    def configure(conf)
      super
    end

    def start
      @loop = Coolio::Loop.new
      @timer = TimerWatcher.new(@emit_interval, true, log, &method(:on_timer))
      @loop.attach(@timer)
      @thread = Thread.new(&method(:run))
    end

    def shutdown
      @loop.watchers.each {|w| w.detach }
      @loop.stop
      @thread.join
    end

    def run
      @loop.run
    rescue
      log.error "unexpected error", error: $!.to_s
      log.error_backtrace
    end

    def on_timer
      now = Engine.now
      record = GC.stat
      router.emit(@tag, now, record)
    end
  end
end

Version data entries

25 entries across 25 versions & 2 rubygems

Version Path
fluentd-0.12.43 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.42 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.41 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.40 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.39 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.38 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.37 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.36 lib/fluent/plugin/in_gc_stat.rb
fluent-plugin-detect-memb-exceptions-0.0.2 vendor/bundle/ruby/2.0.0/gems/fluentd-0.12.35/lib/fluent/plugin/in_gc_stat.rb
fluent-plugin-detect-memb-exceptions-0.0.1 vendor/bundle/ruby/2.0.0/gems/fluentd-0.12.35/lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.35 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.34 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.33 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.32 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.31 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.30 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.29 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.28 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.27 lib/fluent/plugin/in_gc_stat.rb
fluentd-0.12.26 lib/fluent/plugin/in_gc_stat.rb