Sha256: 6760640a3b59c770ce82dcd28d86c0471139ea19c988a90016c9c922078fffbf
Contents?: true
Size: 1.65 KB
Versions: 3
Compression:
Stored size: 1.65 KB
Contents
# frozen_string_literal: true require 'elastic_apm/railtie' require 'elastic_apm/subscriber' require 'elastic_apm/normalizers/rails' module ElasticAPM # Module for explicitly starting the ElasticAPM agent and hooking into Rails. # It is recommended to use the Railtie instead. module Rails extend self # Start the ElasticAPM agent and hook into Rails. # Note that the agent won't be started if the Rails console is being used. # # @param config [Config, Hash] An instance of Config or a Hash config. # @return [true, nil] true if the agent was started, nil otherwise. def start(config) config = Config.new(config) unless config.is_a?(Config) if (reason = should_skip?(config)) unless config.disable_start_message? config.logger.info "Skipping because: #{reason}. " \ "Start manually with `ElasticAPM.start'" end return end ElasticAPM.start(config).tap do |agent| attach_subscriber(agent) end ElasticAPM.running? rescue StandardError => e if config.disable_start_message? config.logger.error format('Failed to start: %s', e.message) config.logger.debug "Backtrace:\n" + e.backtrace.join("\n") else puts format('Failed to start: %s', e.message) puts "Backtrace:\n" + e.backtrace.join("\n") end end private def should_skip?(_config) if ::Rails.const_defined?('Console', false) return 'Rails console' end nil end def attach_subscriber(agent) return unless agent agent.instrumenter.subscriber = ElasticAPM::Subscriber.new(agent) end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
elastic-apm-3.6.0 | lib/elastic_apm/rails.rb |
elastic-apm-3.5.0 | lib/elastic_apm/rails.rb |
elastic-apm-3.4.0 | lib/elastic_apm/rails.rb |