Class: ScoutApm::AgentContext

Inherits:
Object
  • Object
show all
Defined in:
lib/scout_apm/agent_context.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeAgentContext

Initially start up without attempting to load a configuration file. We need to be able to lookup configuration options like “application_root” which would then in turn influence where the yaml configuration file is located

Later in initialization, we set config= to include the file.



12
13
14
15
16
# File 'lib/scout_apm/agent_context.rb', line 12

def initialize()
  @logger = LoggerFactory.build_minimal_logger
  @process_start_time = Time.now
  @extensions = ScoutApm::Extensions::Config.new(self)
end

Instance Attribute Details

#extensionsObject

Returns the value of attribute extensions.



4
5
6
# File 'lib/scout_apm/agent_context.rb', line 4

def extensions
  @extensions
end

#process_start_timeObject (readonly)

Accessors #



68
69
70
# File 'lib/scout_apm/agent_context.rb', line 68

def process_start_time
  @process_start_time
end

Instance Method Details

#auto_instruments_layer_histogramsObject

Maintains a Histogram of insignificant/significant autoinstrument layers. significant = 1 insignificant = 0



113
114
115
# File 'lib/scout_apm/agent_context.rb', line 113

def auto_instruments_layer_histograms
  @auto_instruments_layer_histograms ||= ScoutApm::RequestHistograms.new
end

#become_remote_client!(host, port) ⇒ Object

Execute this in the child process of a remote agent. The parent is expected to have its accepting webserver up and running



57
58
59
60
61
# File 'lib/scout_apm/agent_context.rb', line 57

def become_remote_client!(host, port)
  logger.debug("Becoming Remote Agent (reporting to: #{host}:#{port})")
  @recorder = ScoutApm::Remote::Recorder.new(host, port, logger)
  @store = ScoutApm::FakeStore.new
end

#configObject



70
71
72
# File 'lib/scout_apm/agent_context.rb', line 70

def config
  @config ||= ScoutApm::Config.without_file(self)
end

#config=(config) ⇒ Object

When we set the config for any reason, there are some values we must reinitialize, since the config could have changed their settings, so nil them out here, then let them get lazily reset as needed

Don’t use this in initializer, since it’ll attempt to log immediately



170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
# File 'lib/scout_apm/agent_context.rb', line 170

def config=(config)
  @config = config

  @logger = nil

  log_configuration_settings

  @ignored_uris = nil
  @slow_request_policy = nil
  @slow_job_policy = nil
  @request_histograms = nil
  @request_histograms_by_time = nil
  @store = nil
  @layaway = nil
  @recorder = nil
end

#dev_trace_enabled?Boolean

Returns:

  • (Boolean)


145
146
147
# File 'lib/scout_apm/agent_context.rb', line 145

def dev_trace_enabled?
  config.value('dev_trace') && environment.env == "development"
end

#environmentObject



74
75
76
# File 'lib/scout_apm/agent_context.rb', line 74

def environment
  @environment ||= ScoutApm::Environment.instance
end

#environment=(env) ⇒ Object

I believe this is only useful for testing?



214
215
216
# File 'lib/scout_apm/agent_context.rb', line 214

def environment=(env)
  @environment = env
end

#error_bufferObject

Error Service #



153
154
155
# File 'lib/scout_apm/agent_context.rb', line 153

def error_buffer
  @error_buffer ||= ScoutApm::ErrorService::ErrorBuffer.new(self)
end

#ignored_exceptionsObject



157
158
159
# File 'lib/scout_apm/agent_context.rb', line 157

def ignored_exceptions
  @ignored_exceptions ||= ScoutApm::ErrorService::IgnoredExceptions.new(self, config.value('errors_ignored_exceptions'))
end

#ignored_urisObject



98
99
100
# File 'lib/scout_apm/agent_context.rb', line 98

def ignored_uris
  @ignored_uris ||= ScoutApm::IgnoredUris.new(config.value('ignore'))
end

#installed!Object



187
188
189
# File 'lib/scout_apm/agent_context.rb', line 187

def installed!
  @installed = true
end

#installed?Boolean

Returns:

  • (Boolean)


86
87
88
# File 'lib/scout_apm/agent_context.rb', line 86

def installed?
  @installed
end

#layawayObject



137
138
139
# File 'lib/scout_apm/agent_context.rb', line 137

def layaway
  @layaway ||= ScoutApm::Layaway.new(self)
end

#log_configuration_settingsObject

Called after config is reset and loaded from file



225
226
227
228
229
230
231
232
233
# File 'lib/scout_apm/agent_context.rb', line 225

def log_configuration_settings
  @config.log_settings(logger)

  if !@config.any_keys_found?
    logger.info("No configuration file loaded, and no configuration found in ENV. " +
                "For assistance configuring Scout, visit " +
                "https://docs.scoutapm.com/#ruby-configuration-options")
  end
end

#loggerObject



90
91
92
# File 'lib/scout_apm/agent_context.rb', line 90

def logger
  @logger ||= LoggerFactory.build(config, environment)
end

#marshal_dumpObject



18
19
20
# File 'lib/scout_apm/agent_context.rb', line 18

def marshal_dump
  []
end

#marshal_load(*args) ⇒ Object



22
23
24
25
# File 'lib/scout_apm/agent_context.rb', line 22

def marshal_load(*args)
  @logger = LoggerFactory.build_minimal_logger
  @process_start_time = Time.now
end

#recorderObject



141
142
143
# File 'lib/scout_apm/agent_context.rb', line 141

def recorder
  @recorder ||= RecorderFactory.build(self)
end

#recorder=(recorder) ⇒ Object



209
210
211
# File 'lib/scout_apm/agent_context.rb', line 209

def recorder=(recorder)
  @recorder = recorder
end

#request_histogramsObject

Histogram of the cumulative requests since the start of the process



118
119
120
# File 'lib/scout_apm/agent_context.rb', line 118

def request_histograms
  @request_histograms ||= ScoutApm::RequestHistograms.new
end

#request_histograms_by_timeObject

Histogram of the requests, distinct by reporting period (minute) { StoreReportingPeriodTimestamp => RequestHistograms }



124
125
126
# File 'lib/scout_apm/agent_context.rb', line 124

def request_histograms_by_time
  @request_histograms_by_time ||= Hash.new { |h, k| h[k] = ScoutApm::RequestHistograms.new }
end

#samplingObject



94
95
96
# File 'lib/scout_apm/agent_context.rb', line 94

def sampling
  @sampling ||= ScoutApm::Sampling.new(config)
end

#shutting_down!Object



195
196
197
# File 'lib/scout_apm/agent_context.rb', line 195

def shutting_down!
  @shutting_down = true
end

#shutting_down?Boolean

Returns:

  • (Boolean)


82
83
84
# File 'lib/scout_apm/agent_context.rb', line 82

def shutting_down?
  @shutting_down
end

#slow_job_policyObject



106
107
108
# File 'lib/scout_apm/agent_context.rb', line 106

def slow_job_policy
  @slow_job_policy ||= ScoutApm::SlowRequestPolicy.new(self).tap{|p| p.add_default_policies }
end

#slow_request_policyObject



102
103
104
# File 'lib/scout_apm/agent_context.rb', line 102

def slow_request_policy
  @slow_request_policy ||= ScoutApm::SlowRequestPolicy.new(self).tap{|p| p.add_default_policies }
end

#start_remote_server!(bind, port) ⇒ Object

Lifecycle: Remote Server/Client

This allows short lived forked processes to communicate back to the parent process.
Used in the Resque instrumentation

Parent Pre-fork: start_remote_server! once
Child Post-fork: become_remote_client! after each fork

TODO: Figure out where to extract this to


39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/scout_apm/agent_context.rb', line 39

def start_remote_server!(bind, port)
  return if @remote_server && @remote_server.running?

  logger.info("Starting Remote Agent Server")

  # Start the listening web server only in parent process.
  @remote_server = ScoutApm::Remote::Server.new(
    bind,
    port,
    ScoutApm::Remote::Router.new(ScoutApm::SynchronousRecorder.new(self), logger),
    logger
  )

  @remote_server.start
end

#started!Object



191
192
193
# File 'lib/scout_apm/agent_context.rb', line 191

def started!
  @started = true
end

#started?Boolean

Returns:

  • (Boolean)


78
79
80
# File 'lib/scout_apm/agent_context.rb', line 78

def started?
  @started
end

#storeObject



132
133
134
135
# File 'lib/scout_apm/agent_context.rb', line 132

def store
  return @store if @store
  self.store = ScoutApm::Store.new(self)
end

#store=(store) ⇒ Object



199
200
201
202
203
204
205
206
207
# File 'lib/scout_apm/agent_context.rb', line 199

def store=(store)
  @store = store

  # Installs the default samplers
  # Don't install samplers on nil stores
  if store
    ScoutApm::Instruments::Samplers::DEFAULT_SAMPLERS.each { |s| store.add_sampler(s) }
  end
end

#transaction_time_consumedObject



128
129
130
# File 'lib/scout_apm/agent_context.rb', line 128

def transaction_time_consumed
  @transaction_time_consumed ||= ScoutApm::TransactionTimeConsumed.new
end