Sha256: 4c104aef70f987d1797a19b833f3d9730cd07e01c174119cd0e38680e4cff976
Contents?: true
Size: 1.38 KB
Versions: 3
Compression:
Stored size: 1.38 KB
Contents
require "kurchatov/mixin/queue" module Kurchatov class Monitor class Task include Kurchatov::Mixin::Event include Kurchatov::Mixin::Queue attr_accessor :thread, :instance def initialize(plugin) @plugin = plugin @thread = Thread.new { @plugin.run } end def died? return false if @thread.alive? # thread died, join and extract error begin @thread.join # call error rescue => e desc = "Plugin '#{@plugin.name}' died. #{e.class}: #{e}\n #{e.backtrace.join("\n")}" Log.error(desc) event(:service => "riemann client errors", :desc => desc, :state => 'critical') end @thread = Thread.new { @plugin.run } true end def status {@plugin.name => @thread.alive?} end end attr_accessor :tasks CHECK_ALIVE_TIMEOUT = 5 def initialize(stop = false) @stop_on_error = stop @tasks = Array.new end def <<(plugin) Log.debug("Add new plugin: #{plugin.inspect}") @tasks << Task.new(plugin) end def run loop do @tasks.each { |t| exit Config[:ERROR_PLUGIN_REQ] if t.died? && @stop_on_error } Log.debug("Check alive plugins [#{@tasks.count}]") sleep CHECK_ALIVE_TIMEOUT end end def tasks_status @tasks.map {|t| t.status } end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
kurchatov-0.0.2 | lib/kurchatov/monitor.rb |
kurchatov-0.0.2b | lib/kurchatov/monitor.rb |
kurchatov-0.0.1 | lib/kurchatov/monitor.rb |