# encoding: utf-8 # This file is distributed under New Relic's license terms. # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details. require 'new_relic/language_support' require 'new_relic/agent/null_logger' require 'new_relic/agent/agent_logger' module NewRelic class Control # Contains methods that relate to the runtime usage of the control # object. Note that these are subject to override in the # NewRelic::Control::Framework classes that are actually instantiated module InstanceMethods # The env is the setting used to identify which section of the newrelic.yml # to load. This defaults to a framework specific value, such as ENV['RAILS_ENV'] # but can be overridden as long as you set it before calling #init_plugin attr_writer :env # The local environment contains all the information we report # to the server about what kind of application this is, what # gems and plugins it uses, and many other kinds of # machine-dependent information useful in debugging attr_reader :local_env # Initialize the plugin/gem and start the agent. This does the # necessary configuration based on the framework environment and # determines whether or not to start the agent. If the agent is # not going to be started then it loads the agent shim which has # stubs for all the external api. # # This may be invoked multiple times, as long as you don't attempt # to uninstall the agent after it has been started. # # If the plugin is initialized and it determines that the agent is # not enabled, it will skip starting it and install the shim. But # if you later call this with :agent_enabled => true, # then it will install the real agent and start it. # # What determines whether the agent is launched is the result of # calling agent_enabled? This will indicate whether the # instrumentation should/will be installed. If we're in a mode # where tracers are not installed then we should not start the # agent. # # Subclasses are not allowed to override, but must implement # init_config({}) which is called one or more times. # def init_plugin(options={}) env = options[:env] || self.env Agent.logger.info("Starting the New Relic agent in #{env.inspect} environment.") Agent.logger.info("To prevent agent startup add a NEWRELIC_ENABLE=false environment variable or modify the #{env.inspect} section of your newrelic.yml.") yaml = Agent::Configuration::YamlSource.new(@config_file_path, env) Agent.config.replace_or_add_config(yaml, 1) Agent.config.replace_or_add_config(Agent::Configuration::ManualSource.new(options), 1) # Be sure to only create once! RUBY-1020 if ::NewRelic::Agent.logger.is_startup_logger? ::NewRelic::Agent.logger = NewRelic::Agent::AgentLogger.new(Agent.config, root, options.delete(:log)) end # Merge the stringified options into the config as overrides: environment_name = options.delete(:env) and self.env = environment_name dispatcher_instance_id = options.delete(:dispatcher_instance_id) and @local_env.dispatcher_instance_id = dispatcher_instance_id NewRelic::Agent::PipeChannelManager.listener.start if options.delete(:start_channel_listener) # An artifact of earlier implementation, we put both #add_method_tracer and #trace_execution # methods in the module methods. Module.send :include, NewRelic::Agent::MethodTracer::ClassMethods Module.send :include, NewRelic::Agent::MethodTracer::InstanceMethods init_config(options) NewRelic::Agent.agent = NewRelic::Agent::Agent.instance if Agent.config[:agent_enabled] && !NewRelic::Agent.instance.started? start_agent install_instrumentation load_samplers unless Agent.config[:disable_samplers] elsif !Agent.config[:agent_enabled] install_shim end end # Install the real agent into the Agent module, and issue the start command. def start_agent NewRelic::Agent.agent.start end def app Agent.config[:framework] end def framework Agent.config[:framework] end # for backward compatibility with the old config interface def [](key) NewRelic::Agent.config[key.to_sym] end def settings NewRelic::Agent.config.to_collector_hash end def dispatcher NewRelic::Agent.config[:dispatcher] end # Delegates to the class method newrelic_root, implemented by # each subclass def newrelic_root self.class.newrelic_root end protected def initialize(local_env, config_file_override=nil) @local_env = local_env @instrumentation_files = [] @config_file_path = config_file_override || Agent.config[:config_path] end def root '.' end end include InstanceMethods end end