Class: Mysql2::Metrics
- Inherits:
-
Object
- Object
- Mysql2::Metrics
- Defined in:
- lib/mysql2/metrics.rb,
lib/mysql2/metrics/ltsv_formatter.rb
Defined Under Namespace
Classes: LtsvFormatter
Class Method Summary collapse
- .add_tracer(method) ⇒ Object
- .logger ⇒ Object
- .logger=(logger) ⇒ Object
- .measure_time(query, &block) ⇒ Object
Class Method Details
.add_tracer(method) ⇒ Object
17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/mysql2/metrics.rb', line 17 def self.add_tracer(method) klass = ::Mysql2::Client unless klass.method_defined?("#{method}_without_metrics") klass.__send__(:alias_method, "#{method}_without_metrics", method) klass.__send__(:define_method, "#{method}_with_metrics") do |*args| query = args.first ::Mysql2::Metrics.measure_time(query) do send("#{method}_without_metrics", *args) end end klass.__send__(:alias_method, method, "#{method}_with_metrics") end end |
.logger ⇒ Object
11 12 13 14 15 |
# File 'lib/mysql2/metrics.rb', line 11 def self.logger @logger ||= Logger.new($stdout).tap {|log| log.formatter = ::Mysql2::Metrics::LtsvFormatter.new } end |
.logger=(logger) ⇒ Object
7 8 9 |
# File 'lib/mysql2/metrics.rb', line 7 def self.logger=(logger) @logger = logger end |