Sha256: 81d46020f9bf9481a7c4e6c329659a62d27d9f6848fad3ffdb80c1024646973f

Contents?: true

Size: 1.35 KB

Versions: 12

Compression:

Stored size: 1.35 KB

Contents

module Oxidized
  class Jobs < Array
    AVERAGE_DURATION  = 5   # initially presume nodes take 5s to complete
    MAX_INTER_JOB_GAP = 300 # add job if more than X from last job started
    attr_accessor :interval, :max, :want

    def initialize max, interval, nodes
      @max       = max
      @interval  = interval
      @nodes     = nodes
      @last      = Time.now.utc
      @durations = Array.new @nodes.size, AVERAGE_DURATION
      duration AVERAGE_DURATION
      super()
    end

    def push arg
      @last = Time.now.utc
      super
    end

    def duration last
      @durations.push(last).shift
      @duration = @durations.inject(:+).to_f / @nodes.size #rolling average
      new_count
    end

    def new_count
      @want = ((@nodes.size * @duration) / @interval).to_i
      @want = 1 if @want < 1
      @want = @nodes.size if @want > @nodes.size
      @want = @max if @want > @max
    end

    def work
      # if   a) we want less or same amount of threads as we now running
      # and  b) we want less threads running than the total amount of nodes
      # and  c) there is more than MAX_INTER_JOB_GAP since last one was started
      # then we want one more thread (rationale is to fix hanging thread causing HOLB)
      if @want <= size and @want < @nodes.size
        @want +=1 if (Time.now.utc - @last) > MAX_INTER_JOB_GAP
      end
    end

  end
end

Version data entries

12 entries across 12 versions & 1 rubygems

Version Path
oxidized-0.11.0 lib/oxidized/jobs.rb
oxidized-0.10.0 lib/oxidized/jobs.rb
oxidized-0.9.0 lib/oxidized/jobs.rb
oxidized-0.8.1 lib/oxidized/jobs.rb
oxidized-0.8.0 lib/oxidized/jobs.rb
oxidized-0.7.2 lib/oxidized/jobs.rb
oxidized-0.7.1 lib/oxidized/jobs.rb
oxidized-0.7.0 lib/oxidized/jobs.rb
oxidized-0.6.0 lib/oxidized/jobs.rb
oxidized-0.5.0 lib/oxidized/jobs.rb
oxidized-0.4.1 lib/oxidized/jobs.rb
oxidized-0.4.0 lib/oxidized/jobs.rb