Class: ScoutApm::Store
- Inherits:
-
Object
- Object
- ScoutApm::Store
- Defined in:
- lib/scout_apm/store.rb
Instance Method Summary collapse
-
#add_sampler(sampler_klass) ⇒ Object
Sampler support.
- #current_timestamp ⇒ Object
-
#initialize(context) ⇒ Store
constructor
A new instance of Store.
-
#tick! ⇒ Object
For each tick (minute), be sure we have a reporting period, and that samplers are run for it.
-
#track!(metrics, options = {}) ⇒ Object
Save newly collected metrics.
- #track_db_query_metrics!(db_query_metric_set, options = {}) ⇒ Object
- #track_external_service_metrics!(external_service_metric_set, options = {}) ⇒ Object
- #track_histograms!(histograms, options = {}) ⇒ Object
- #track_job!(job) ⇒ Object
- #track_one!(type, name, value, options = {}) ⇒ Object
- #track_slow_job!(job) ⇒ Object
-
#track_slow_transaction!(slow_transaction) ⇒ Object
Save a new slow transaction.
-
#write_to_layaway(layaway, force = false) ⇒ Object
Take each completed reporting_period, and write it to the layaway passed.
Constructor Details
#initialize(context) ⇒ Store
Returns a new instance of Store.
6 7 8 9 10 11 12 13 |
# File 'lib/scout_apm/store.rb', line 6 def initialize(context) @context = context @mutex = Monitor.new @reporting_periods = Hash.new { |h,k| @mutex.synchronize { h[k] = StoreReportingPeriod.new(k, @context) } } @samplers = [] end |
Instance Method Details
#add_sampler(sampler_klass) ⇒ Object
Sampler support
127 128 129 |
# File 'lib/scout_apm/store.rb', line 127 def add_sampler(sampler_klass) @samplers << sampler_klass.new(@context) end |
#current_timestamp ⇒ Object
15 16 17 |
# File 'lib/scout_apm/store.rb', line 15 def StoreReportingPeriodTimestamp.new(Time.now) end |
#tick! ⇒ Object
For each tick (minute), be sure we have a reporting period, and that samplers are run for it.
109 110 111 112 |
# File 'lib/scout_apm/store.rb', line 109 def tick! rp = current_period collect_samplers(rp) end |
#track!(metrics, options = {}) ⇒ Object
Save newly collected metrics
34 35 36 37 38 39 |
# File 'lib/scout_apm/store.rb', line 34 def track!(metrics, ={}) @mutex.synchronize { period = find_period([:timestamp]) period.absorb_metrics!(metrics) } end |
#track_db_query_metrics!(db_query_metric_set, options = {}) ⇒ Object
48 49 50 51 52 53 |
# File 'lib/scout_apm/store.rb', line 48 def track_db_query_metrics!(db_query_metric_set, ={}) @mutex.synchronize { period = find_period([:timestamp]) period.merge_db_query_metrics!(db_query_metric_set) } end |
#track_external_service_metrics!(external_service_metric_set, options = {}) ⇒ Object
55 56 57 58 59 60 |
# File 'lib/scout_apm/store.rb', line 55 def track_external_service_metrics!(external_service_metric_set, ={}) @mutex.synchronize { period = find_period([:timestamp]) period.merge_external_service_metrics!(external_service_metric_set) } end |
#track_histograms!(histograms, options = {}) ⇒ Object
41 42 43 44 45 46 |
# File 'lib/scout_apm/store.rb', line 41 def track_histograms!(histograms, ={}) @mutex.synchronize { period = find_period([:timestamp]) period.merge_histograms!(histograms) } end |
#track_job!(job) ⇒ Object
77 78 79 80 81 82 |
# File 'lib/scout_apm/store.rb', line 77 def track_job!(job) return if job.nil? @mutex.synchronize { current_period.merge_jobs!(Array(job)) } end |
#track_one!(type, name, value, options = {}) ⇒ Object
62 63 64 65 66 67 |
# File 'lib/scout_apm/store.rb', line 62 def track_one!(type, name, value, ={}) = MetricMeta.new("#{type}/#{name}") stat = MetricStats.new(false) stat.update!(value) track!({ => stat}, ) end |
#track_slow_job!(job) ⇒ Object
84 85 86 87 88 89 |
# File 'lib/scout_apm/store.rb', line 84 def track_slow_job!(job) return if job.nil? @mutex.synchronize { current_period.merge_slow_jobs!(Array(job)) } end |
#track_slow_transaction!(slow_transaction) ⇒ Object
Save a new slow transaction
70 71 72 73 74 75 |
# File 'lib/scout_apm/store.rb', line 70 def track_slow_transaction!(slow_transaction) return unless slow_transaction @mutex.synchronize { current_period.merge_slow_transactions!(slow_transaction) } end |
#write_to_layaway(layaway, force = false) ⇒ Object
Take each completed reporting_period, and write it to the layaway passed
force - a boolean argument that forces this function to write current-minute metrics. Useful when we are shutting down the agent during a restart.
96 97 98 99 100 101 102 103 104 105 106 |
# File 'lib/scout_apm/store.rb', line 96 def write_to_layaway(layaway, force=false) logger.debug("Writing to layaway#{" (Forced)" if force}") to_report = @mutex.synchronize { @reporting_periods.select { |time, rp| force || (time. < .) } } to_report.each { |time, rp| write_reporting_period(layaway, time, rp) } end |