Sha256: 44d9338064eb46dc49de3ded723bd5899c9fbfebc218b32866095bc95ac228aa

Contents?: true

Size: 1.09 KB

Versions: 6

Compression:

Stored size: 1.09 KB

Contents

module Dexter
  class Collector
    def initialize(options = {})
      @top_queries = {}
      @new_queries = Set.new
      @mutex = Mutex.new
      @min_time = options[:min_time] * 60000 # convert minutes to ms
    end

    def add(query, duration)
      fingerprint =
        begin
          PgQuery.fingerprint(query)
        rescue PgQuery::ParseError
          # do nothing
        end

      return unless fingerprint

      @top_queries[fingerprint] ||= {calls: 0, total_time: 0}
      @top_queries[fingerprint][:calls] += 1
      @top_queries[fingerprint][:total_time] += duration
      @top_queries[fingerprint][:query] = query
      @mutex.synchronize do
        @new_queries << fingerprint
      end
    end

    def fetch_queries
      new_queries = nil

      @mutex.synchronize do
        new_queries = @new_queries.dup
        @new_queries.clear
      end

      queries = []
      @top_queries.each do |k, v|
        if new_queries.include?(k) && v[:total_time] > @min_time
          queries << Query.new(v[:query], k)
        end
      end

      queries.sort_by(&:fingerprint)
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
pgdexter-0.2.0 lib/dexter/collector.rb
pgdexter-0.1.6 lib/dexter/collector.rb
pgdexter-0.1.5 lib/dexter/collector.rb
pgdexter-0.1.4 lib/dexter/collector.rb
pgdexter-0.1.3 lib/dexter/collector.rb
pgdexter-0.1.2 lib/dexter/collector.rb