Sha256: be2f94f0214f338e630d0461530483fc093780e48216a49069179e4f8dbe2f92

Contents?: true

Size: 1.04 KB

Versions: 2

Compression:

Stored size: 1.04 KB

Contents

class Eye::Trigger::Flapping < Eye::Trigger

  # triggers :flapping, :times => 10, :within => 1.minute,
  #          :retry_in => 10.minutes, :retry_times => 15

  param :times, [Fixnum], true, 5
  param :within, [Float, Fixnum], true
  param :retry_in, [Float, Fixnum]
  param :retry_times, [Fixnum]

  def initialize(*args)
    super
    @last_at = nil
  end

  def check(transition)
    on_flapping if transition.event == :crashed && !good?
  end

private

  def good?
    states = process.states_history.states_for_period( within, @last_at )
    down_count = states.count{|st| st == :down }

    if down_count >= times
      @last_at = process.states_history.last_state_changed_at
      false
    else
      true
    end
  end

  def on_flapping
    debug 'flapping recognized!!!'

    process.notify :error, 'flapping!'
    process.schedule :unmonitor, Eye::Reason.new(:flapping)

    return unless retry_in
    return if retry_times && process.flapping_times >= retry_times

    process.schedule_in(retry_in.to_f, :retry_start_after_flapping)
  end

end

Version data entries

2 entries across 2 versions & 2 rubygems

Version Path
reel-eye-0.5 lib/eye/trigger/flapping.rb
eye-0.5 lib/eye/trigger/flapping.rb