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 |