Sha256: e05fbed7cd171906ea01bca3e216670e7dc25dc497d0355216c65c26fcee7235

Contents?: true

Size: 1.58 KB

Versions: 2

Compression:

Stored size: 1.58 KB

Contents

class DataProviders::DiskActivity
  def initialize(settings)
    @settings = self.class.default_settings.merge(settings)

    @reads_sec = 0
    @writes_sec = 0

    @thread = Thread.new do
      last_time = last_reads = last_writes = 0
      first_time = true
      while(true)
        time = (Time.new.to_f * 1000).to_i

        reads, writes = IO.readlines("/proc/diskstats").map { |l| parts = l.split; [parts[5].to_i, parts[9].to_i] }.inject([0, 0]) { |sum, vals| [sum[0] + vals[0], sum[1] + vals[1]] }

        if first_time
          first_time = false
        else
          @reads_sec = ((reads - last_reads) / ((time - last_time).to_f / 1000.0)) * 512
          @writes_sec = ((writes - last_writes) / ((time - last_time).to_f / 1000.0)) * 512
        end
        last_reads = reads
        last_writes = writes
        last_time = time
        sleep(@settings[:update_rate])
      end
    end
  end

  def get
    { :reads => @reads_sec / 1024.0 / 1024.0, :writes => @writes_sec / 1024.0 / 1024.0 }
  end

  def renderer
    information.merge({ :contents => %{
sc.innerHTML = "<div class='major_figure'><span class='title'>Reads</span><span class='figure'>" + data_source['reads'] + "</span><span class='unit'>mb/s</span></div>" +
"<div class='major_figure'><span class='title'>Writes</span><span class='figure'>" + data_source['writes'] + "</span><span class='unit'>mb/s</span></div>";
} })
  end

  def self.default_settings
    { :update_rate => 2.5 }
  end

  def information
    { :name => "Disk Activity", :in_sentence => "Disk Activity", :importance => 70 }
  end

  def kill
    @thread.kill
  end
end

Version data entries

2 entries across 2 versions & 2 rubygems

Version Path
bloopletech-webstats-0.10.5 server/data_providers/disk_activity.rb
webstats-0.1.0 server/data_providers/disk_activity.rb