newrelic_rpm 5.7.0.350 → 9.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.gitignore +15 -1
- data/.rubocop.yml +1919 -0
- data/.rubocop_todo.yml +100 -0
- data/.simplecov +15 -0
- data/.snyk +11 -0
- data/.yardopts +2 -0
- data/Brewfile +12 -0
- data/CHANGELOG.md +4056 -2339
- data/CONTRIBUTING.md +132 -19
- data/DOCKER.md +167 -0
- data/Dockerfile +10 -0
- data/Gemfile +5 -2
- data/Guardfile +22 -4
- data/LICENSE +202 -38
- data/README.md +87 -87
- data/Rakefile +27 -27
- data/THIRD_PARTY_NOTICES.md +28 -0
- data/Thorfile +5 -0
- data/bin/newrelic +3 -2
- data/bin/newrelic_cmd +1 -0
- data/bin/nrdebug +77 -54
- data/config.dot +5 -5
- data/docker-compose.yml +107 -0
- data/init.rb +5 -7
- data/install.rb +3 -3
- data/lefthook.yml +9 -0
- data/lib/new_relic/agent/adaptive_sampler.rb +14 -10
- data/lib/new_relic/agent/agent.rb +125 -969
- data/lib/new_relic/agent/agent_helpers/connect.rb +227 -0
- data/lib/new_relic/agent/agent_helpers/harvest.rb +153 -0
- data/lib/new_relic/agent/agent_helpers/shutdown.rb +72 -0
- data/lib/new_relic/agent/agent_helpers/special_startup.rb +74 -0
- data/lib/new_relic/agent/agent_helpers/start_worker_thread.rb +167 -0
- data/lib/new_relic/agent/agent_helpers/startup.rb +202 -0
- data/lib/new_relic/agent/agent_helpers/transmit.rb +76 -0
- data/lib/new_relic/agent/agent_logger.rb +26 -18
- data/lib/new_relic/agent/attribute_filter.rb +69 -52
- data/lib/new_relic/agent/attribute_processing.rb +8 -8
- data/lib/new_relic/agent/attributes.rb +153 -0
- data/lib/new_relic/agent/audit_logger.rb +19 -4
- data/lib/new_relic/agent/autostart.rb +34 -28
- data/lib/new_relic/agent/chained_call.rb +2 -2
- data/lib/new_relic/agent/commands/agent_command.rb +4 -4
- data/lib/new_relic/agent/commands/agent_command_router.rb +15 -33
- data/lib/new_relic/agent/commands/thread_profiler_session.rb +13 -11
- data/lib/new_relic/agent/configuration/default_source.rb +1480 -1053
- data/lib/new_relic/agent/configuration/dotted_hash.rb +7 -6
- data/lib/new_relic/agent/configuration/environment_source.rb +15 -11
- data/lib/new_relic/agent/configuration/event_harvest_config.rb +68 -0
- data/lib/new_relic/agent/configuration/high_security_source.rb +9 -9
- data/lib/new_relic/agent/configuration/manager.rb +96 -79
- data/lib/new_relic/agent/configuration/manual_source.rb +2 -2
- data/lib/new_relic/agent/configuration/mask_defaults.rb +4 -4
- data/lib/new_relic/agent/configuration/security_policy_source.rb +83 -86
- data/lib/new_relic/agent/configuration/server_source.rb +49 -12
- data/lib/new_relic/agent/configuration/yaml_source.rb +42 -13
- data/lib/new_relic/agent/configuration.rb +2 -2
- data/lib/new_relic/agent/connect/request_builder.rb +61 -0
- data/lib/new_relic/agent/connect/response_handler.rb +58 -0
- data/lib/new_relic/agent/custom_event_aggregator.rb +15 -15
- data/lib/new_relic/agent/database/explain_plan_helpers.rb +5 -6
- data/lib/new_relic/agent/database/obfuscation_helpers.rb +16 -15
- data/lib/new_relic/agent/database/obfuscator.rb +3 -3
- data/lib/new_relic/agent/database/postgres_explain_obfuscator.rb +4 -4
- data/lib/new_relic/agent/database.rb +44 -53
- data/lib/new_relic/agent/database_adapter.rb +35 -0
- data/lib/new_relic/agent/datastores/metric_helper.rb +18 -20
- data/lib/new_relic/agent/datastores/mongo/event_formatter.rb +9 -8
- data/lib/new_relic/agent/datastores/mongo/metric_translator.rb +7 -11
- data/lib/new_relic/agent/datastores/mongo.rb +7 -12
- data/lib/new_relic/agent/datastores/nosql_obfuscator.rb +41 -0
- data/lib/new_relic/agent/datastores/redis.rb +6 -12
- data/lib/new_relic/agent/datastores.rb +19 -23
- data/lib/new_relic/agent/deprecator.rb +2 -2
- data/lib/new_relic/agent/{cross_app_payload.rb → distributed_tracing/cross_app_payload.rb} +13 -12
- data/lib/new_relic/agent/{cross_app_tracing.rb → distributed_tracing/cross_app_tracing.rb} +87 -66
- data/lib/new_relic/agent/distributed_tracing/distributed_trace_attributes.rb +84 -0
- data/lib/new_relic/agent/distributed_tracing/distributed_trace_metrics.rb +75 -0
- data/lib/new_relic/agent/distributed_tracing/distributed_trace_payload.rb +163 -0
- data/lib/new_relic/agent/distributed_tracing/distributed_trace_transport_type.rb +38 -0
- data/lib/new_relic/agent/distributed_tracing/trace_context.rb +245 -0
- data/lib/new_relic/agent/distributed_tracing/trace_context_payload.rb +127 -0
- data/lib/new_relic/agent/distributed_tracing.rb +113 -32
- data/lib/new_relic/agent/encoding_normalizer.rb +5 -3
- data/lib/new_relic/agent/error_collector.rb +99 -63
- data/lib/new_relic/agent/error_event_aggregator.rb +10 -8
- data/lib/new_relic/agent/error_filter.rb +174 -0
- data/lib/new_relic/agent/error_trace_aggregator.rb +6 -4
- data/lib/new_relic/agent/event_aggregator.rb +43 -48
- data/lib/new_relic/agent/event_buffer.rb +8 -9
- data/lib/new_relic/agent/event_listener.rb +2 -3
- data/lib/new_relic/agent/event_loop.rb +27 -25
- data/lib/new_relic/agent/external.rb +20 -51
- data/lib/new_relic/agent/guid_generator.rb +30 -0
- data/lib/new_relic/agent/harvester.rb +5 -6
- data/lib/new_relic/agent/heap.rb +8 -10
- data/lib/new_relic/agent/hostname.rb +26 -5
- data/lib/new_relic/agent/http_clients/abstract.rb +81 -0
- data/lib/new_relic/agent/http_clients/curb_wrappers.rb +26 -26
- data/lib/new_relic/agent/http_clients/excon_wrappers.rb +31 -17
- data/lib/new_relic/agent/http_clients/http_rb_wrappers.rb +18 -23
- data/lib/new_relic/agent/http_clients/httpclient_wrappers.rb +12 -15
- data/lib/new_relic/agent/http_clients/net_http_wrappers.rb +24 -8
- data/lib/new_relic/agent/http_clients/typhoeus_wrappers.rb +9 -12
- data/lib/new_relic/agent/http_clients/uri_util.rb +12 -13
- data/lib/new_relic/agent/instrumentation/action_cable_subscriber.rb +22 -52
- data/lib/new_relic/agent/instrumentation/action_controller_other_subscriber.rb +39 -0
- data/lib/new_relic/agent/instrumentation/action_controller_subscriber.rb +59 -72
- data/lib/new_relic/agent/instrumentation/action_dispatch.rb +31 -0
- data/lib/new_relic/agent/instrumentation/action_dispatch_subscriber.rb +64 -0
- data/lib/new_relic/agent/instrumentation/action_mailbox.rb +30 -0
- data/lib/new_relic/agent/instrumentation/action_mailbox_subscriber.rb +33 -0
- data/lib/new_relic/agent/instrumentation/action_mailer.rb +30 -0
- data/lib/new_relic/agent/instrumentation/action_mailer_subscriber.rb +85 -0
- data/lib/new_relic/agent/instrumentation/action_view_subscriber.rb +86 -62
- data/lib/new_relic/agent/instrumentation/active_job.rb +38 -19
- data/lib/new_relic/agent/instrumentation/active_job_subscriber.rb +41 -0
- data/lib/new_relic/agent/instrumentation/active_merchant.rb +21 -7
- data/lib/new_relic/agent/instrumentation/active_record.rb +95 -46
- data/lib/new_relic/agent/instrumentation/active_record_helper.rb +82 -61
- data/lib/new_relic/agent/instrumentation/active_record_notifications.rb +155 -0
- data/lib/new_relic/agent/instrumentation/active_record_prepend.rb +36 -12
- data/lib/new_relic/agent/instrumentation/active_record_subscriber.rb +69 -64
- data/lib/new_relic/agent/instrumentation/active_storage.rb +8 -4
- data/lib/new_relic/agent/instrumentation/active_storage_subscriber.rb +11 -32
- data/lib/new_relic/agent/instrumentation/active_support.rb +27 -0
- data/lib/new_relic/agent/instrumentation/active_support_logger/chain.rb +23 -0
- data/lib/new_relic/agent/instrumentation/active_support_logger/instrumentation.rb +20 -0
- data/lib/new_relic/agent/instrumentation/active_support_logger/prepend.rb +12 -0
- data/lib/new_relic/agent/instrumentation/active_support_logger.rb +24 -0
- data/lib/new_relic/agent/instrumentation/active_support_subscriber.rb +41 -0
- data/lib/new_relic/agent/instrumentation/bunny/chain.rb +45 -0
- data/lib/new_relic/agent/instrumentation/bunny/instrumentation.rb +150 -0
- data/lib/new_relic/agent/instrumentation/bunny/prepend.rb +35 -0
- data/lib/new_relic/agent/instrumentation/bunny.rb +14 -134
- data/lib/new_relic/agent/instrumentation/concurrent_ruby/chain.rb +36 -0
- data/lib/new_relic/agent/instrumentation/concurrent_ruby/instrumentation.rb +21 -0
- data/lib/new_relic/agent/instrumentation/concurrent_ruby/prepend.rb +27 -0
- data/lib/new_relic/agent/instrumentation/concurrent_ruby.rb +31 -0
- data/lib/new_relic/agent/instrumentation/controller_instrumentation.rb +77 -61
- data/lib/new_relic/agent/instrumentation/curb/chain.rb +91 -0
- data/lib/new_relic/agent/instrumentation/curb/instrumentation.rb +221 -0
- data/lib/new_relic/agent/instrumentation/curb/prepend.rb +61 -0
- data/lib/new_relic/agent/instrumentation/curb.rb +15 -187
- data/lib/new_relic/agent/instrumentation/custom_events.rb +12 -0
- data/lib/new_relic/agent/instrumentation/custom_events_subscriber.rb +37 -0
- data/lib/new_relic/agent/instrumentation/delayed_job/chain.rb +35 -0
- data/lib/new_relic/agent/instrumentation/delayed_job/instrumentation.rb +48 -0
- data/lib/new_relic/agent/instrumentation/delayed_job/prepend.rb +33 -0
- data/lib/new_relic/agent/instrumentation/delayed_job_instrumentation.rb +30 -52
- data/lib/new_relic/agent/instrumentation/elasticsearch/chain.rb +29 -0
- data/lib/new_relic/agent/instrumentation/elasticsearch/instrumentation.rb +66 -0
- data/lib/new_relic/agent/instrumentation/elasticsearch/prepend.rb +13 -0
- data/lib/new_relic/agent/instrumentation/elasticsearch.rb +31 -0
- data/lib/new_relic/agent/instrumentation/excon/middleware.rb +8 -7
- data/lib/new_relic/agent/instrumentation/excon.rb +29 -31
- data/lib/new_relic/agent/instrumentation/fiber/chain.rb +20 -0
- data/lib/new_relic/agent/instrumentation/fiber/instrumentation.rb +24 -0
- data/lib/new_relic/agent/instrumentation/fiber/prepend.rb +18 -0
- data/lib/new_relic/agent/instrumentation/fiber.rb +25 -0
- data/lib/new_relic/agent/instrumentation/grape/chain.rb +24 -0
- data/lib/new_relic/agent/instrumentation/grape/instrumentation.rb +100 -0
- data/lib/new_relic/agent/instrumentation/grape/prepend.rb +17 -0
- data/lib/new_relic/agent/instrumentation/grape.rb +16 -121
- data/lib/new_relic/agent/instrumentation/grpc/client/chain.rb +97 -0
- data/lib/new_relic/agent/instrumentation/grpc/client/instrumentation.rb +89 -0
- data/lib/new_relic/agent/instrumentation/grpc/client/prepend.rb +111 -0
- data/lib/new_relic/agent/instrumentation/grpc/client/request_wrapper.rb +30 -0
- data/lib/new_relic/agent/instrumentation/grpc/helper.rb +32 -0
- data/lib/new_relic/agent/instrumentation/grpc/server/chain.rb +69 -0
- data/lib/new_relic/agent/instrumentation/grpc/server/instrumentation.rb +134 -0
- data/lib/new_relic/agent/instrumentation/grpc/server/rpc_desc_prepend.rb +35 -0
- data/lib/new_relic/agent/instrumentation/grpc/server/rpc_server_prepend.rb +26 -0
- data/lib/new_relic/agent/instrumentation/grpc_client.rb +23 -0
- data/lib/new_relic/agent/instrumentation/grpc_server.rb +25 -0
- data/lib/new_relic/agent/instrumentation/httpclient/chain.rb +24 -0
- data/lib/new_relic/agent/instrumentation/httpclient/instrumentation.rb +37 -0
- data/lib/new_relic/agent/instrumentation/httpclient/prepend.rb +15 -0
- data/lib/new_relic/agent/instrumentation/httpclient.rb +12 -32
- data/lib/new_relic/agent/instrumentation/httprb/chain.rb +22 -0
- data/lib/new_relic/agent/instrumentation/httprb/instrumentation.rb +30 -0
- data/lib/new_relic/agent/instrumentation/httprb/prepend.rb +15 -0
- data/lib/new_relic/agent/instrumentation/httprb.rb +29 -0
- data/lib/new_relic/agent/instrumentation/ignore_actions.rb +5 -6
- data/lib/new_relic/agent/instrumentation/logger/chain.rb +21 -0
- data/lib/new_relic/agent/instrumentation/logger/instrumentation.rb +66 -0
- data/lib/new_relic/agent/instrumentation/logger/prepend.rb +13 -0
- data/lib/new_relic/agent/instrumentation/logger.rb +26 -0
- data/lib/new_relic/agent/instrumentation/memcache/chain.rb +15 -0
- data/lib/new_relic/agent/instrumentation/memcache/dalli.rb +58 -125
- data/lib/new_relic/agent/instrumentation/memcache/helper.rb +59 -0
- data/lib/new_relic/agent/instrumentation/memcache/instrumentation.rb +90 -0
- data/lib/new_relic/agent/instrumentation/memcache/prepend.rb +101 -0
- data/lib/new_relic/agent/instrumentation/memcache.rb +57 -71
- data/lib/new_relic/agent/instrumentation/middleware_proxy.rb +15 -14
- data/lib/new_relic/agent/instrumentation/middleware_tracing.rb +21 -14
- data/lib/new_relic/agent/instrumentation/mongo.rb +7 -132
- data/lib/new_relic/agent/instrumentation/mongodb_command_subscriber.rb +49 -13
- data/lib/new_relic/agent/instrumentation/net_http/chain.rb +24 -0
- data/lib/new_relic/agent/instrumentation/net_http/instrumentation.rb +40 -0
- data/lib/new_relic/agent/instrumentation/net_http/prepend.rb +21 -0
- data/lib/new_relic/agent/instrumentation/net_http.rb +44 -0
- data/lib/new_relic/agent/instrumentation/notifications_subscriber.rb +142 -0
- data/lib/new_relic/agent/instrumentation/padrino/chain.rb +38 -0
- data/lib/new_relic/agent/instrumentation/padrino/instrumentation.rb +28 -0
- data/lib/new_relic/agent/instrumentation/padrino/prepend.rb +20 -0
- data/lib/new_relic/agent/instrumentation/padrino.rb +22 -58
- data/lib/new_relic/agent/instrumentation/passenger_instrumentation.rb +7 -7
- data/lib/new_relic/agent/instrumentation/queue_time.rb +9 -10
- data/lib/new_relic/agent/instrumentation/rack/chain.rb +66 -0
- data/lib/new_relic/agent/instrumentation/rack/helpers.rb +33 -0
- data/lib/new_relic/agent/instrumentation/rack/instrumentation.rb +75 -0
- data/lib/new_relic/agent/instrumentation/rack/prepend.rb +43 -0
- data/lib/new_relic/agent/instrumentation/rack.rb +33 -141
- data/lib/new_relic/agent/instrumentation/rails3/action_controller.rb +19 -55
- data/lib/new_relic/agent/instrumentation/rails_middleware.rb +5 -5
- data/lib/new_relic/agent/instrumentation/rails_notifications/action_cable.rb +36 -0
- data/lib/new_relic/agent/instrumentation/rails_notifications/action_controller.rb +45 -0
- data/lib/new_relic/agent/instrumentation/rails_notifications/action_view.rb +30 -0
- data/lib/new_relic/agent/instrumentation/rails_notifications/custom_events.rb +30 -0
- data/lib/new_relic/agent/instrumentation/rake/chain.rb +20 -0
- data/lib/new_relic/agent/instrumentation/rake/instrumentation.rb +142 -0
- data/lib/new_relic/agent/instrumentation/rake/prepend.rb +14 -0
- data/lib/new_relic/agent/instrumentation/rake.rb +18 -159
- data/lib/new_relic/agent/instrumentation/redis/chain.rb +45 -0
- data/lib/new_relic/agent/instrumentation/redis/constants.rb +17 -0
- data/lib/new_relic/agent/instrumentation/redis/instrumentation.rb +93 -0
- data/lib/new_relic/agent/instrumentation/redis/middleware.rb +16 -0
- data/lib/new_relic/agent/instrumentation/redis/prepend.rb +29 -0
- data/lib/new_relic/agent/instrumentation/redis.rb +20 -103
- data/lib/new_relic/agent/instrumentation/resque/chain.rb +21 -0
- data/lib/new_relic/agent/instrumentation/resque/helper.rb +19 -0
- data/lib/new_relic/agent/instrumentation/resque/instrumentation.rb +34 -0
- data/lib/new_relic/agent/instrumentation/resque/prepend.rb +15 -0
- data/lib/new_relic/agent/instrumentation/resque.rb +33 -41
- data/lib/new_relic/agent/instrumentation/sequel.rb +17 -20
- data/lib/new_relic/agent/instrumentation/sequel_helper.rb +3 -3
- data/lib/new_relic/agent/instrumentation/sidekiq/client.rb +20 -0
- data/lib/new_relic/agent/instrumentation/sidekiq/extensions/delayed_class.rb +30 -0
- data/lib/new_relic/agent/instrumentation/sidekiq/server.rb +37 -0
- data/lib/new_relic/agent/instrumentation/sidekiq.rb +29 -46
- data/lib/new_relic/agent/instrumentation/sinatra/chain.rb +55 -0
- data/lib/new_relic/agent/instrumentation/sinatra/ignorer.rb +31 -37
- data/lib/new_relic/agent/instrumentation/sinatra/instrumentation.rb +125 -0
- data/lib/new_relic/agent/instrumentation/sinatra/prepend.rb +33 -0
- data/lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb +3 -3
- data/lib/new_relic/agent/instrumentation/sinatra.rb +35 -165
- data/lib/new_relic/agent/instrumentation/thread/chain.rb +24 -0
- data/lib/new_relic/agent/instrumentation/thread/instrumentation.rb +28 -0
- data/lib/new_relic/agent/instrumentation/thread/prepend.rb +22 -0
- data/lib/new_relic/agent/instrumentation/thread.rb +20 -0
- data/lib/new_relic/agent/instrumentation/tilt/chain.rb +24 -0
- data/lib/new_relic/agent/instrumentation/tilt/instrumentation.rb +41 -0
- data/lib/new_relic/agent/instrumentation/tilt/prepend.rb +13 -0
- data/lib/new_relic/agent/instrumentation/tilt.rb +25 -0
- data/lib/new_relic/agent/instrumentation/typhoeus/chain.rb +22 -0
- data/lib/new_relic/agent/instrumentation/typhoeus/instrumentation.rb +80 -0
- data/lib/new_relic/agent/instrumentation/typhoeus/prepend.rb +14 -0
- data/lib/new_relic/agent/instrumentation/typhoeus.rb +14 -76
- data/lib/new_relic/agent/instrumentation.rb +2 -2
- data/lib/new_relic/agent/internal_agent_error.rb +3 -3
- data/lib/new_relic/agent/javascript_instrumentor.rb +51 -45
- data/lib/new_relic/agent/linking_metadata.rb +44 -0
- data/lib/new_relic/agent/local_log_decorator.rb +37 -0
- data/lib/new_relic/agent/log_event_aggregator.rb +235 -0
- data/lib/new_relic/agent/log_once.rb +2 -2
- data/lib/new_relic/agent/log_priority.rb +20 -0
- data/lib/new_relic/agent/logging.rb +142 -0
- data/lib/new_relic/agent/memory_logger.rb +3 -3
- data/lib/new_relic/agent/messaging.rb +81 -164
- data/lib/new_relic/agent/method_tracer.rb +152 -145
- data/lib/new_relic/agent/method_tracer_helpers.rb +90 -13
- data/lib/new_relic/agent/monitors/cross_app_monitor.rb +117 -0
- data/lib/new_relic/agent/monitors/distributed_tracing_monitor.rb +28 -0
- data/lib/new_relic/agent/{inbound_request_monitor.rb → monitors/inbound_request_monitor.rb} +5 -6
- data/lib/new_relic/agent/{synthetics_monitor.rb → monitors/synthetics_monitor.rb} +9 -15
- data/lib/new_relic/agent/monitors.rb +26 -0
- data/lib/new_relic/agent/new_relic_service/encoders.rb +7 -7
- data/lib/new_relic/agent/new_relic_service/json_marshaller.rb +6 -7
- data/lib/new_relic/agent/new_relic_service/marshaller.rb +8 -29
- data/lib/new_relic/agent/new_relic_service/security_policy_settings.rb +5 -5
- data/lib/new_relic/agent/new_relic_service.rb +282 -166
- data/lib/new_relic/agent/noticeable_error.rb +19 -0
- data/lib/new_relic/agent/null_logger.rb +8 -4
- data/lib/new_relic/agent/obfuscator.rb +9 -11
- data/lib/new_relic/agent/parameter_filtering.rb +35 -8
- data/lib/new_relic/agent/payload_metric_mapping.rb +10 -11
- data/lib/new_relic/agent/pipe_channel_manager.rb +28 -18
- data/lib/new_relic/agent/pipe_service.rb +9 -6
- data/lib/new_relic/agent/prepend_supportability.rb +3 -3
- data/lib/new_relic/agent/priority_sampled_buffer.rb +16 -14
- data/lib/new_relic/agent/range_extensions.rb +9 -29
- data/lib/new_relic/agent/rules_engine/replacement_rule.rb +12 -12
- data/lib/new_relic/agent/rules_engine/segment_terms_rule.rb +13 -14
- data/lib/new_relic/agent/rules_engine.rb +6 -5
- data/lib/new_relic/agent/sampler.rb +4 -5
- data/lib/new_relic/agent/sampler_collection.rb +4 -5
- data/lib/new_relic/agent/samplers/cpu_sampler.rb +4 -3
- data/lib/new_relic/agent/samplers/delayed_job_sampler.rb +14 -11
- data/lib/new_relic/agent/samplers/memory_sampler.rb +26 -15
- data/lib/new_relic/agent/samplers/object_sampler.rb +2 -2
- data/lib/new_relic/agent/samplers/vm_sampler.rb +22 -20
- data/lib/new_relic/agent/span_event_aggregator.rb +14 -16
- data/lib/new_relic/agent/span_event_primitive.rb +118 -58
- data/lib/new_relic/agent/sql_sampler.rb +25 -25
- data/lib/new_relic/agent/stats.rb +79 -42
- data/lib/new_relic/agent/stats_engine/gc_profiler.rb +11 -13
- data/lib/new_relic/agent/stats_engine/stats_hash.rb +13 -14
- data/lib/new_relic/agent/stats_engine.rb +11 -11
- data/lib/new_relic/agent/synthetics_event_aggregator.rb +8 -9
- data/lib/new_relic/agent/system_info.rb +100 -66
- data/lib/new_relic/agent/threading/agent_thread.rb +20 -16
- data/lib/new_relic/agent/threading/backtrace_node.rb +13 -14
- data/lib/new_relic/agent/threading/backtrace_service.rb +18 -18
- data/lib/new_relic/agent/threading/thread_profile.rb +31 -45
- data/lib/new_relic/agent/timestamp_sampled_buffer.rb +2 -2
- data/lib/new_relic/agent/tracer.rb +513 -0
- data/lib/new_relic/agent/transaction/abstract_segment.rb +131 -41
- data/lib/new_relic/agent/transaction/datastore_segment.rb +22 -18
- data/lib/new_relic/agent/transaction/distributed_tracer.rb +184 -0
- data/lib/new_relic/agent/transaction/distributed_tracing.rb +72 -163
- data/lib/new_relic/agent/transaction/external_request_segment.rb +66 -63
- data/lib/new_relic/agent/transaction/message_broker_segment.rb +34 -46
- data/lib/new_relic/agent/transaction/request_attributes.rb +36 -36
- data/lib/new_relic/agent/transaction/segment.rb +46 -10
- data/lib/new_relic/agent/transaction/slowest_sample_buffer.rb +2 -4
- data/lib/new_relic/agent/transaction/synthetics_sample_buffer.rb +2 -2
- data/lib/new_relic/agent/transaction/trace.rb +21 -24
- data/lib/new_relic/agent/transaction/trace_builder.rb +11 -12
- data/lib/new_relic/agent/transaction/trace_context.rb +168 -0
- data/lib/new_relic/agent/transaction/trace_node.rb +31 -28
- data/lib/new_relic/agent/transaction/tracing.rb +15 -111
- data/lib/new_relic/agent/transaction/transaction_sample_buffer.rb +6 -6
- data/lib/new_relic/agent/transaction.rb +252 -259
- data/lib/new_relic/agent/transaction_error_primitive.rb +34 -37
- data/lib/new_relic/agent/transaction_event_aggregator.rb +13 -13
- data/lib/new_relic/agent/transaction_event_primitive.rb +44 -56
- data/lib/new_relic/agent/transaction_event_recorder.rb +17 -16
- data/lib/new_relic/agent/transaction_metrics.rb +11 -10
- data/lib/new_relic/agent/transaction_sampler.rb +7 -12
- data/lib/new_relic/agent/transaction_time_aggregator.rb +41 -26
- data/lib/new_relic/agent/utilization/aws.rb +34 -4
- data/lib/new_relic/agent/utilization/azure.rb +4 -4
- data/lib/new_relic/agent/utilization/gcp.rb +8 -8
- data/lib/new_relic/agent/utilization/pcf.rb +6 -5
- data/lib/new_relic/agent/utilization/vendor.rb +44 -29
- data/lib/new_relic/agent/utilization_data.rb +43 -6
- data/lib/new_relic/agent/vm/jruby_vm.rb +2 -2
- data/lib/new_relic/agent/vm/monotonic_gc_profiler.rb +3 -3
- data/lib/new_relic/agent/vm/mri_vm.rb +46 -19
- data/lib/new_relic/agent/vm/snapshot.rb +6 -6
- data/lib/new_relic/agent/vm.rb +2 -2
- data/lib/new_relic/agent/worker_loop.rb +11 -13
- data/lib/new_relic/agent.rb +151 -79
- data/lib/new_relic/cli/command.rb +21 -23
- data/lib/new_relic/cli/commands/deployments.rb +94 -45
- data/lib/new_relic/cli/commands/install.rb +24 -26
- data/lib/new_relic/coerce.rb +42 -15
- data/lib/new_relic/collection_helper.rb +51 -49
- data/lib/new_relic/constants.rb +39 -0
- data/lib/new_relic/control/class_methods.rb +11 -5
- data/lib/new_relic/control/frameworks/external.rb +3 -3
- data/lib/new_relic/control/frameworks/rails.rb +24 -18
- data/lib/new_relic/control/frameworks/rails3.rb +4 -5
- data/lib/new_relic/control/frameworks/rails4.rb +2 -2
- data/lib/new_relic/control/frameworks/rails_notifications.rb +14 -0
- data/lib/new_relic/control/frameworks/ruby.rb +4 -4
- data/lib/new_relic/control/frameworks/sinatra.rb +8 -2
- data/lib/new_relic/control/frameworks.rb +2 -2
- data/lib/new_relic/control/instance_methods.rb +33 -42
- data/lib/new_relic/control/instrumentation.rb +40 -12
- data/lib/new_relic/control/private_instance_methods.rb +48 -0
- data/lib/new_relic/control/server_methods.rb +4 -5
- data/lib/new_relic/control.rb +2 -3
- data/lib/new_relic/delayed_job_injection.rb +2 -2
- data/lib/new_relic/dependency_detection.rb +129 -18
- data/lib/new_relic/environment_report.rb +41 -35
- data/lib/new_relic/helper.rb +49 -8
- data/lib/new_relic/language_support.rb +30 -6
- data/lib/new_relic/latest_changes.rb +9 -8
- data/lib/new_relic/local_environment.rb +23 -27
- data/lib/new_relic/metric_data.rb +32 -27
- data/lib/new_relic/metric_spec.rb +9 -7
- data/lib/new_relic/noticed_error.rb +46 -33
- data/lib/new_relic/rack/agent_hooks.rb +2 -2
- data/lib/new_relic/rack/agent_middleware.rb +7 -5
- data/lib/new_relic/rack/browser_monitoring.rb +134 -117
- data/lib/new_relic/rack.rb +2 -2
- data/lib/new_relic/recipes/capistrano3.rb +4 -62
- data/lib/new_relic/recipes/capistrano_legacy.rb +24 -27
- data/lib/new_relic/recipes/helpers/send_deployment.rb +70 -0
- data/lib/new_relic/recipes.rb +2 -2
- data/lib/new_relic/supportability_helper.rb +21 -7
- data/lib/new_relic/traced_thread.rb +39 -0
- data/lib/new_relic/version.rb +7 -18
- data/lib/newrelic_rpm.rb +20 -33
- data/lib/sequel/extensions/{newrelic_instrumentation.rb → new_relic_instrumentation.rb} +16 -19
- data/lib/sequel/plugins/{newrelic_instrumentation.rb → new_relic_instrumentation.rb} +9 -15
- data/lib/tasks/all.rb +4 -4
- data/lib/tasks/config.rake +22 -118
- data/lib/tasks/coverage_report.rake +28 -0
- data/lib/tasks/helpers/config.html.erb +21 -0
- data/lib/tasks/helpers/format.rb +123 -0
- data/lib/tasks/helpers/matches.rb +12 -0
- data/lib/tasks/helpers/prompt.rb +24 -0
- data/lib/tasks/helpers/removers.rb +33 -0
- data/lib/tasks/install.rake +4 -0
- data/lib/tasks/instrumentation_generator/README.md +63 -0
- data/lib/tasks/instrumentation_generator/TODO.md +33 -0
- data/lib/tasks/instrumentation_generator/instrumentation.thor +121 -0
- data/lib/tasks/instrumentation_generator/templates/Envfile.tt +9 -0
- data/lib/tasks/instrumentation_generator/templates/chain.tt +22 -0
- data/lib/tasks/instrumentation_generator/templates/chain_method.tt +8 -0
- data/lib/tasks/instrumentation_generator/templates/dependency_detection.tt +29 -0
- data/lib/tasks/instrumentation_generator/templates/instrumentation.tt +13 -0
- data/lib/tasks/instrumentation_generator/templates/instrumentation_method.tt +3 -0
- data/lib/tasks/instrumentation_generator/templates/newrelic.yml.tt +19 -0
- data/lib/tasks/instrumentation_generator/templates/prepend.tt +13 -0
- data/lib/tasks/instrumentation_generator/templates/prepend_method.tt +3 -0
- data/lib/tasks/instrumentation_generator/templates/test.tt +15 -0
- data/lib/tasks/multiverse.rake +4 -0
- data/lib/tasks/multiverse.rb +12 -5
- data/lib/tasks/newrelic.rb +2 -2
- data/lib/tasks/tests.rake +14 -14
- data/newrelic.yml +672 -3
- data/newrelic_rpm.gemspec +40 -31
- data/recipes/newrelic.rb +3 -3
- data/test/agent_helper.rb +419 -98
- metadata +238 -127
- data/.travis.yml +0 -228
- data/bin/mongrel_rpm +0 -33
- data/cert/cacert.pem +0 -1177
- data/lib/new_relic/agent/commands/xray_session.rb +0 -55
- data/lib/new_relic/agent/commands/xray_session_collection.rb +0 -161
- data/lib/new_relic/agent/cross_app_monitor.rb +0 -110
- data/lib/new_relic/agent/datastores/mongo/obfuscator.rb +0 -44
- data/lib/new_relic/agent/datastores/mongo/statement_formatter.rb +0 -53
- data/lib/new_relic/agent/distributed_trace_monitor.rb +0 -41
- data/lib/new_relic/agent/distributed_trace_payload.rb +0 -246
- data/lib/new_relic/agent/http_clients/abstract_request.rb +0 -31
- data/lib/new_relic/agent/instrumentation/active_record_4.rb +0 -42
- data/lib/new_relic/agent/instrumentation/active_record_5.rb +0 -41
- data/lib/new_relic/agent/instrumentation/acts_as_solr.rb +0 -74
- data/lib/new_relic/agent/instrumentation/authlogic.rb +0 -25
- data/lib/new_relic/agent/instrumentation/data_mapper.rb +0 -202
- data/lib/new_relic/agent/instrumentation/evented_subscriber.rb +0 -104
- data/lib/new_relic/agent/instrumentation/excon/connection.rb +0 -46
- data/lib/new_relic/agent/instrumentation/http.rb +0 -46
- data/lib/new_relic/agent/instrumentation/merb/controller.rb +0 -44
- data/lib/new_relic/agent/instrumentation/merb/errors.rb +0 -33
- data/lib/new_relic/agent/instrumentation/net.rb +0 -50
- data/lib/new_relic/agent/instrumentation/rails/action_controller.rb +0 -125
- data/lib/new_relic/agent/instrumentation/rails/action_web_service.rb +0 -46
- data/lib/new_relic/agent/instrumentation/rails4/action_controller.rb +0 -32
- data/lib/new_relic/agent/instrumentation/rails4/action_view.rb +0 -27
- data/lib/new_relic/agent/instrumentation/rails5/action_cable.rb +0 -36
- data/lib/new_relic/agent/instrumentation/rails5/action_controller.rb +0 -33
- data/lib/new_relic/agent/instrumentation/rails5/action_view.rb +0 -27
- data/lib/new_relic/agent/instrumentation/rainbows_instrumentation.rb +0 -26
- data/lib/new_relic/agent/instrumentation/sunspot.rb +0 -33
- data/lib/new_relic/agent/supported_versions.rb +0 -275
- data/lib/new_relic/agent/transaction/attributes.rb +0 -154
- data/lib/new_relic/agent/transaction/xray_sample_buffer.rb +0 -64
- data/lib/new_relic/agent/transaction_state.rb +0 -186
- data/lib/new_relic/build.rb +0 -2
- data/lib/new_relic/control/frameworks/merb.rb +0 -29
- data/lib/new_relic/control/frameworks/rails5.rb +0 -14
- data/lib/new_relic/metrics.rb +0 -13
- data/lib/tasks/config.html.erb +0 -32
- data/lib/tasks/versions.html.erb +0 -28
- data/lib/tasks/versions.postface.html +0 -8
- data/lib/tasks/versions.preface.html +0 -9
- data/lib/tasks/versions.rake +0 -65
- data/lib/tasks/versions.txt.erb +0 -14
- /data/lib/tasks/{config.text.erb → helpers/config.text.erb} +0 -0
data/newrelic.yml
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
# This file configures the New Relic Agent. New Relic monitors Ruby, Java,
|
3
3
|
# .NET, PHP, Python, Node, and Go applications with deep visibility and low
|
4
4
|
# overhead. For more information, visit www.newrelic.com.
|
5
|
-
|
5
|
+
|
6
6
|
# Generated <%= Time.now.strftime('%B %d, %Y') %><%= ", for version #{@agent_version}" if @agent_version %>
|
7
7
|
#<%= "\n# #{generated_for_user}\n#" if generated_for_user %>
|
8
8
|
# For full documentation of agent configuration options, please refer to
|
@@ -13,15 +13,684 @@ common: &default_settings
|
|
13
13
|
license_key: <%= license_key %>
|
14
14
|
|
15
15
|
# Your application name. Renaming here affects where data displays in New
|
16
|
-
# Relic.
|
16
|
+
# Relic. For more details, see https://docs.newrelic.com/docs/apm/new-relic-apm/maintenance/renaming-applications
|
17
17
|
app_name: <%= app_name %>
|
18
18
|
|
19
19
|
# To disable the agent regardless of other settings, uncomment the following:
|
20
20
|
# agent_enabled: false
|
21
21
|
|
22
|
-
# Logging level for log/newrelic_agent.log
|
22
|
+
# Logging level for log/newrelic_agent.log; options are error, warn, info, or
|
23
|
+
# debug.
|
23
24
|
log_level: info
|
24
25
|
|
26
|
+
# All of the following configuration options are optional. Review them, and
|
27
|
+
# uncomment or edit them if they appear relevant to your application needs.
|
28
|
+
|
29
|
+
# An array of ActiveSupport custom events names to subscribe to and provide
|
30
|
+
# instrumentation for. For example,
|
31
|
+
# - my.custom.event
|
32
|
+
# - another.event
|
33
|
+
# - a.third.event
|
34
|
+
# active_support_custom_events_names: ""
|
35
|
+
|
36
|
+
# If `true`, all logging-related features for the agent can be enabled or disabled
|
37
|
+
# independently. If `false`, all logging-related features are disabled.
|
38
|
+
# application_logging.enabled: true
|
39
|
+
|
40
|
+
# If `true`, the agent captures log records emitted by this application.
|
41
|
+
# application_logging.forwarding.enabled: true
|
42
|
+
|
43
|
+
# Defines the maximum number of log records to buffer in memory at a time.
|
44
|
+
# application_logging.forwarding.max_samples_stored: 10000
|
45
|
+
|
46
|
+
# If `true`, the agent captures metrics related to logging for this application.
|
47
|
+
# application_logging.metrics.enabled: true
|
48
|
+
|
49
|
+
# If `true`, the agent decorates logs with metadata to link to entities, hosts, traces, and spans.
|
50
|
+
# application_logging.local_decorating.enabled: false
|
51
|
+
|
52
|
+
# If `true`, the agent will report source code level metrics for traced methods
|
53
|
+
# see: https://docs.newrelic.com/docs/apm/agents/ruby-agent/features/ruby-codestream-integration/
|
54
|
+
# code_level_metrics.enabled: true
|
55
|
+
|
56
|
+
# If true, enables transaction event sampling.
|
57
|
+
# transaction_events.enabled: true
|
58
|
+
|
59
|
+
# Defines the maximum number of request events reported from a single harvest.
|
60
|
+
# transaction_events.max_samples_stored: 1200
|
61
|
+
|
62
|
+
# Prefix of attributes to exclude from all destinations. Allows * as wildcard at
|
63
|
+
# end.
|
64
|
+
# attributes_exclude: []
|
65
|
+
|
66
|
+
# Prefix of attributes to include in all destinations. Allows * as wildcard at
|
67
|
+
# end.
|
68
|
+
# attributes_include: []
|
69
|
+
|
70
|
+
# If true, enables capture of attributes for all destinations.
|
71
|
+
# attributes.enabled: true
|
72
|
+
|
73
|
+
# If true, enables an audit log which logs communications with the New Relic
|
74
|
+
# collector.
|
75
|
+
# audit_log.enabled: false
|
76
|
+
|
77
|
+
# List of allowed endpoints to include in audit log.
|
78
|
+
# audit_log.endpoints: [".*"]
|
79
|
+
|
80
|
+
# Specifies a path to the audit log file (including the filename).
|
81
|
+
# audit_log.path: "/audit_log"
|
82
|
+
|
83
|
+
# Specify a list of constants that should prevent the agent from starting
|
84
|
+
# automatically. Separate individual constants with a comma ,.
|
85
|
+
# For example, Rails::Console,UninstrumentedBackgroundJob.
|
86
|
+
# autostart.denylisted_constants: "rails::console"
|
87
|
+
|
88
|
+
# Defines a comma-delimited list of executables that the agent should not
|
89
|
+
# instrument. For example, rake,my_ruby_script.rb.
|
90
|
+
# autostart.denylisted_executables: "irb,rspec"
|
91
|
+
|
92
|
+
# Defines a comma-delimited list of Rake tasks that the agent should not
|
93
|
+
# instrument. For example, assets:precompile,db:migrate.
|
94
|
+
# autostart.denylisted_rake_tasks: "about,assets:clean,assets:clobber,assets:environment,assets:precompile,assets:precompile:all,db:create,db:drop,db:fixtures:load,db:migrate,db:migrate:status,db:rollback,db:schema:cache:clear,db:schema:cache:dump,db:schema:dump,db:schema:load,db:seed,db:setup,db:structure:dump,db:version,doc:app,log:clear,middleware,notes,notes:custom,rails:template,rails:update,routes,secret,spec,spec:features,spec:requests,spec:controllers,spec:helpers,spec:models,spec:views,spec:routing,spec:rcov,stats,test,test:all,test:all:db,test:recent,test:single,test:uncommitted,time:zones:all,tmp:clear,tmp:create,webpacker:compile"
|
95
|
+
|
96
|
+
# Backports the faster Active Record connection lookup introduced in Rails 6,
|
97
|
+
# which improves agent performance when instrumenting Active Record. Note that
|
98
|
+
# this setting may not be compatible with other gems that patch Active Record.
|
99
|
+
# backport_fast_active_record_connection_lookup: false
|
100
|
+
|
101
|
+
# If true, the agent captures attributes from browser monitoring.
|
102
|
+
# browser_monitoring.attributes.enabled: false
|
103
|
+
|
104
|
+
# Prefix of attributes to exclude from browser monitoring. Allows * as wildcard
|
105
|
+
# at end.
|
106
|
+
# browser_monitoring.attributes.exclude: []
|
107
|
+
|
108
|
+
# Prefix of attributes to include in browser monitoring. Allows * as wildcard at
|
109
|
+
# end.
|
110
|
+
# browser_monitoring.attributes.include: []
|
111
|
+
|
112
|
+
# This is true by default, this enables auto-injection of the JavaScript header
|
113
|
+
# for page load timing (sometimes referred to as real user monitoring or RUM).
|
114
|
+
# browser_monitoring.auto_instrument: true
|
115
|
+
|
116
|
+
# Manual override for the path to your local CA bundle. This CA bundle will be
|
117
|
+
# used to validate the SSL certificate presented by New Relic's data collection
|
118
|
+
# service.
|
119
|
+
# ca_bundle_path: nil
|
120
|
+
|
121
|
+
# Enable or disable the capture of memcache keys from transaction traces.
|
122
|
+
# capture_memcache_keys: false
|
123
|
+
|
124
|
+
# When true, the agent captures HTTP request parameters and attaches them to
|
125
|
+
# transaction traces, traced errors, and TransactionError events. When using the
|
126
|
+
# capture_params setting, the Ruby agent will not attempt to filter secret
|
127
|
+
# information. Recommendation: To filter secret information from request
|
128
|
+
# parameters,use the attributes.include setting instead. For more information,
|
129
|
+
# see the Ruby attribute examples.
|
130
|
+
# capture_params: false
|
131
|
+
|
132
|
+
# If true, the agent will clear Tracer::State in Agent.drop_buffered_data.
|
133
|
+
# clear_transaction_state_after_fork: false
|
134
|
+
|
135
|
+
# Path to newrelic.yml. If undefined, the agent checks the following directories
|
136
|
+
# (in order): config/newrelic.yml, newrelic.yml, $HOME/.newrelic/newrelic.yml
|
137
|
+
# and $HOME/newrelic.yml.
|
138
|
+
# config_path: newrelic.yml
|
139
|
+
|
140
|
+
# If true, enables cross application tracing. Cross application tracing is now
|
141
|
+
# deprecated, and disabled by default. Distributed tracing is replacing cross
|
142
|
+
# application tracing as the default means of tracing between services.
|
143
|
+
# To continue using it, set `cross_application_tracer.enabled: true` and
|
144
|
+
# `distributed_tracing.enabled: false`
|
145
|
+
# cross_application_tracer.enabled: false
|
146
|
+
|
147
|
+
# If false, custom attributes will not be sent on New Relic Insights events.
|
148
|
+
# custom_attributes.enabled: true
|
149
|
+
|
150
|
+
# If true, the agent captures New Relic Insights custom events.
|
151
|
+
# custom_insights_events.enabled: true
|
152
|
+
|
153
|
+
# Specify a maximum number of custom Insights events to buffer in memory at a
|
154
|
+
# time.
|
155
|
+
# custom_insights_events.max_samples_stored: 3000
|
156
|
+
|
157
|
+
# If false, the agent will not add database_name parameter to transaction or #
|
158
|
+
# slow sql traces.
|
159
|
+
# datastore_tracer.database_name_reporting.enabled: true
|
160
|
+
|
161
|
+
# If false, the agent will not report datastore instance metrics, nor add host
|
162
|
+
# or port_path_or_id parameters to transaction or slow SQL traces.
|
163
|
+
# datastore_tracer.instance_reporting.enabled: true
|
164
|
+
|
165
|
+
# If true, disables Action Cable instrumentation.
|
166
|
+
# disable_action_cable_instrumentation: false
|
167
|
+
|
168
|
+
# If true, disables Action Mailbox instrumentation.
|
169
|
+
# disable_action_mailbox: false
|
170
|
+
|
171
|
+
# If true, disables Action Mailer instrumentation.
|
172
|
+
# disable_action_mailer: false
|
173
|
+
|
174
|
+
# If true, disables instrumentation for Active Record 4+
|
175
|
+
# disable_active_record_notifications: false
|
176
|
+
|
177
|
+
# If true, disables Active Storage instrumentation.
|
178
|
+
# disable_active_storage: false
|
179
|
+
|
180
|
+
# If true, disables Active Support instrumentation.
|
181
|
+
# disable_active_support: false
|
182
|
+
|
183
|
+
# If true, disables Active Job instrumentation.
|
184
|
+
# disable_activejob: false
|
185
|
+
|
186
|
+
# If true, disables Active Record instrumentation.
|
187
|
+
# disable_active_record_instrumentation: false
|
188
|
+
|
189
|
+
# If true, the agent won't sample the CPU usage of the host process.
|
190
|
+
# disable_cpu_sampler: false
|
191
|
+
|
192
|
+
# If true, disables ActiveSupport custom events instrumentation.
|
193
|
+
# disable_custom_events_instrumentation: false
|
194
|
+
|
195
|
+
# If true, the agent won't measure the depth of Delayed Job queues.
|
196
|
+
# disable_delayed_job_sampler: false
|
197
|
+
|
198
|
+
# If true, disables the use of GC::Profiler to measure time spent in garbage
|
199
|
+
# collection
|
200
|
+
# disable_gc_profiler: false
|
201
|
+
|
202
|
+
# If true, the agent won't sample the memory usage of the host process.
|
203
|
+
# disable_memory_sampler: false
|
204
|
+
|
205
|
+
# If true, the agent won't wrap third-party middlewares in instrumentation
|
206
|
+
# (regardless of whether they are installed via Rack::Builder or Rails).
|
207
|
+
# disable_middleware_instrumentation: false
|
208
|
+
|
209
|
+
# If true, disables the collection of sampler metrics. Sampler metrics are
|
210
|
+
# metrics that are not event-based (such as CPU time or memory usage).
|
211
|
+
# disable_samplers: false
|
212
|
+
|
213
|
+
# If true, disables Sequel instrumentation.
|
214
|
+
# disable_sequel_instrumentation: false
|
215
|
+
|
216
|
+
# If true, disables Sidekiq instrumentation.
|
217
|
+
# disable_sidekiq: false
|
218
|
+
|
219
|
+
# If true, disables agent middleware for Sinatra. This middleware is responsible
|
220
|
+
# for advanced feature support such as distributed tracing, page load
|
221
|
+
# timing, and error collection.
|
222
|
+
# disable_sinatra_auto_middleware: false
|
223
|
+
|
224
|
+
# If true, disables view instrumentation.
|
225
|
+
# disable_view_instrumentation: false
|
226
|
+
|
227
|
+
# If true, the agent won't sample performance measurements from the Ruby VM.
|
228
|
+
# disable_vm_sampler: false
|
229
|
+
|
230
|
+
# Distributed tracing tracks and observes service requests as they flow through distributed systems.
|
231
|
+
# With distributed tracing data, you can quickly pinpoint failures or performance issues and fix them.
|
232
|
+
# distributed_tracing.enabled: true
|
233
|
+
|
234
|
+
# If true, the agent captures attributes from error collection.
|
235
|
+
# error_collector.attributes.enabled: false
|
236
|
+
|
237
|
+
# Prefix of attributes to exclude from error collection.
|
238
|
+
# Allows * as wildcard at end.
|
239
|
+
# error_collector.attributes.exclude: []
|
240
|
+
|
241
|
+
# Prefix of attributes to include in error collection.
|
242
|
+
# Allows * as wildcard at end.
|
243
|
+
# error_collector.attributes.include: []
|
244
|
+
|
245
|
+
# If true, the agent collects TransactionError events.
|
246
|
+
# error_collector.capture_events: true
|
247
|
+
|
248
|
+
# If true, the agent captures traced errors and error count metrics.
|
249
|
+
# error_collector.enabled: true
|
250
|
+
|
251
|
+
# A list of error classes that the agent should treat as expected.
|
252
|
+
# error_collector.expected_classes: []
|
253
|
+
|
254
|
+
# A map of error classes to a list of messages. When an error of one of the
|
255
|
+
# classes specified here occurs, if its error message contains one of the
|
256
|
+
# strings corresponding to it here, that error will be treated as expected.
|
257
|
+
# error_collector.expected_messages: {}
|
258
|
+
|
259
|
+
# A comma separated list of status codes, possibly including ranges. Errors
|
260
|
+
# associated with these status codes, where applicable, will be treated as
|
261
|
+
# expected.
|
262
|
+
# error_collector.expected_status_codes: ""
|
263
|
+
|
264
|
+
# A list of error classes that the agent should ignore.
|
265
|
+
# error_collector.ignore_classes: []
|
266
|
+
|
267
|
+
# A map of error classes to a list of messages. When an error of one of the
|
268
|
+
# classes specified here occurs, if its error message contains one of the
|
269
|
+
# strings corresponding to it here, that error will be ignored.
|
270
|
+
# error_collector.ignore_messages: ""
|
271
|
+
|
272
|
+
# A comma separated list of status codes, possibly including ranges. Errors
|
273
|
+
# associated with these status codes, where applicable, will be ignored.
|
274
|
+
# error_collector.ignore_status_codes: ""
|
275
|
+
|
276
|
+
# Defines the maximum number of frames in an error backtrace. Backtraces over
|
277
|
+
# this amount are truncated at the beginning and end.
|
278
|
+
# error_collector.max_backtrace_frames: 50
|
279
|
+
|
280
|
+
# Defines the maximum number of TransactionError events sent to Insights per
|
281
|
+
# harvest cycle.
|
282
|
+
# error_collector.max_event_samples_stored: 100
|
283
|
+
|
284
|
+
# Allows newrelic distributed tracing headers to be suppressed on outbound
|
285
|
+
# requests.
|
286
|
+
# exclude_newrelic_header: false
|
287
|
+
|
288
|
+
# Forces the exit handler that sends all cached data to collector before
|
289
|
+
# shutting down to be installed regardless of detecting scenarios where it
|
290
|
+
# generally should not be. Known use-case for this option is where Sinatra is
|
291
|
+
# running as an embedded service within another framework and the agent is
|
292
|
+
# detecting the Sinatra app and skipping the at_exit handler as a result.
|
293
|
+
# Sinatra classically runs the entire application in an at_exit block and would
|
294
|
+
# otherwise misbehave if the Agent's at_exit handler was also installed in
|
295
|
+
# those circumstances. Note: send_data_on_exit should also be set to true in
|
296
|
+
# tandem with this setting.
|
297
|
+
# force_install_exit_handler: false
|
298
|
+
|
299
|
+
# Ordinarily the agent reports dyno names with a trailing dot and process ID
|
300
|
+
# (for example, worker.3). You can remove this trailing data by specifying the
|
301
|
+
# prefixes you want to report without trailing data (for example, worker).
|
302
|
+
# heroku.dyno_name_prefixes_to_shorten: ["scheduler", "run"]
|
303
|
+
|
304
|
+
# If true, the agent uses Heroku dyno names as the hostname.
|
305
|
+
# heroku.use_dyno_names: true
|
306
|
+
|
307
|
+
# If true, enables high security mode. Ensure that you understand the
|
308
|
+
# implication of enabling high security mode before enabling this setting.
|
309
|
+
# https://docs.newrelic.com/docs/agents/manage-apm-agents/configuration/high-security-mode/
|
310
|
+
# high_security: false
|
311
|
+
|
312
|
+
# Configures the hostname for the Trace Observer Host. When configured, enables
|
313
|
+
# tail-based sampling by sending all recorded spans to a Trace Observer for
|
314
|
+
# further sampling decisions, irrespective of any usual agent sampling decision.
|
315
|
+
# infinite_tracing.trace_observer.host: ""
|
316
|
+
|
317
|
+
# Configures the TCP/IP port for the Trace Observer Host
|
318
|
+
# infinite_tracing.trace_observer.port: 443
|
319
|
+
|
320
|
+
# Configure the compression level for data sent to the Trace Observer
|
321
|
+
# May be one of [none|low|medium|high]
|
322
|
+
# 'high' is the default. Set the level to 'none' to disable compression
|
323
|
+
# infinite_tracing.compression_level: high
|
324
|
+
|
325
|
+
# If true (the default), data sent to the Trace Observer will be batched
|
326
|
+
# instead of each span being sent individually
|
327
|
+
# infinite_tracing.batching: true
|
328
|
+
|
329
|
+
# Controls auto-instrumentation of bunny at start up.
|
330
|
+
# May be one of [auto|prepend|chain|disabled].
|
331
|
+
# instrumentation.bunny: auto
|
332
|
+
|
333
|
+
# Controls auto-instrumentation of Fiber at start up.
|
334
|
+
# May be one of [auto|prepend|chain|disabled]
|
335
|
+
# instrumentation.fiber: auto
|
336
|
+
|
337
|
+
# Controls auto-instrumentation of concurrent_ruby at start up.
|
338
|
+
# May be one of [auto|prepend|chain|disabled]
|
339
|
+
# instrumentation.concurrent_ruby: auto
|
340
|
+
|
341
|
+
# Controls auto-instrumentation of Curb at start up.
|
342
|
+
# May be one of [auto|prepend|chain|disabled].
|
343
|
+
# instrumentation.curb: auto
|
344
|
+
|
345
|
+
# Controls auto-instrumentation of Delayed Job at start up.
|
346
|
+
# May be one of [auto|prepend|chain|disabled].
|
347
|
+
# instrumentation.delayed_job: auto
|
348
|
+
|
349
|
+
# Controls auto-instrumentation of the elasticsearch library at start up.
|
350
|
+
# May be one of [auto|prepend|chain|disabled].
|
351
|
+
# instrumentation.elasticsearch: auto
|
352
|
+
|
353
|
+
# Controls auto-instrumentation of Excon at start up.
|
354
|
+
# May be one of [enabled|disabled].
|
355
|
+
# instrumentation.excon: auto
|
356
|
+
|
357
|
+
# Controls auto-instrumentation of Grape at start up.
|
358
|
+
# May be one of [auto|prepend|chain|disabled].
|
359
|
+
# instrumentation.grape: auto
|
360
|
+
|
361
|
+
# Controls auto-instrumentation of HTTPClient at start up.
|
362
|
+
# May be one of [auto|prepend|chain|disabled].
|
363
|
+
# instrumentation.httpclient: auto
|
364
|
+
|
365
|
+
# Controls auto-instrumentation of http.rb gem at start up.
|
366
|
+
# May be one of [auto|prepend|chain|disabled].
|
367
|
+
# instrumentation.httprb: auto
|
368
|
+
|
369
|
+
# Controls auto-instrumentation of the Ruby standard library Logger.rb.
|
370
|
+
# May be one of [auto|prepend|chain|disabled].
|
371
|
+
# instrumentation.logger: auto
|
372
|
+
|
373
|
+
# Controls auto-instrumentation of ActiveSupport::Logger at start up.
|
374
|
+
# May be one of [auto|prepend|chain|disabled].
|
375
|
+
# instrumentation.active_support.logger: auto
|
376
|
+
|
377
|
+
# Controls auto-instrumentation of memcache-client gem for Memcache at start up.
|
378
|
+
# May be one of [auto|prepend|chain|disabled].
|
379
|
+
# instrumentation.memcache_client: auto
|
380
|
+
|
381
|
+
# Controls auto-instrumentation of dalli gem for Memcache at start up.
|
382
|
+
# May be one of [auto|prepend|chain|disabled].
|
383
|
+
# instrumentation.memcache: auto
|
384
|
+
|
385
|
+
# Controls auto-instrumentation of memcached gem for Memcache at start up.
|
386
|
+
# May be one of [auto|prepend|chain|disabled].
|
387
|
+
# instrumentation.memcached: auto
|
388
|
+
|
389
|
+
# Controls auto-instrumentation of Mongo at start up.
|
390
|
+
# May be one of [enabled|disabled].
|
391
|
+
# instrumentation.mongo: auto
|
392
|
+
|
393
|
+
# Controls auto-instrumentation of Net::HTTP at start up.
|
394
|
+
# May be one of [auto|prepend|chain|disabled].
|
395
|
+
# instrumentation.net_http: auto
|
396
|
+
|
397
|
+
# Controls auto-instrumentation of Puma::Rack::URLMap at start up.
|
398
|
+
# May be one of [auto|prepend|chain|disabled].
|
399
|
+
# instrumentation.puma_rack_urlmap: auto
|
400
|
+
|
401
|
+
# Controls auto-instrumentation of Puma::Rack. When enabled, the agent hooks
|
402
|
+
# into the to_app method in Puma::Rack::Builder to find gems to instrument
|
403
|
+
# during application startup. May be one of [auto|prepend|chain|disabled].
|
404
|
+
# instrumentation.puma_rack: auto
|
405
|
+
|
406
|
+
# Controls auto-instrumentation of Rack::URLMap at start up.
|
407
|
+
# May be one of [auto|prepend|chain|disabled].
|
408
|
+
# instrumentation.rack_urlmap: auto
|
409
|
+
|
410
|
+
# Controls auto-instrumentation of Rack. When enabled, the agent hooks into the
|
411
|
+
# to_app method in Rack::Builder to find gems to instrument during application
|
412
|
+
# startup. May be one of [auto|prepend|chain|disabled].
|
413
|
+
# instrumentation.rack: auto
|
414
|
+
|
415
|
+
# Controls auto-instrumentation of rake at start up.
|
416
|
+
# May be one of [auto|prepend|chain|disabled].
|
417
|
+
# instrumentation.rake: auto
|
418
|
+
|
419
|
+
# Controls auto-instrumentation of Redis at start up.
|
420
|
+
# May be one of [auto|prepend|chain|disabled].
|
421
|
+
# instrumentation.redis: auto
|
422
|
+
|
423
|
+
# Controls auto-instrumentation of resque at start up.
|
424
|
+
# May be one of [auto|prepend|chain|disabled].
|
425
|
+
# instrumentation.resque: auto
|
426
|
+
|
427
|
+
# Controls auto-instrumentation of Sinatra at start up.
|
428
|
+
# May be one of [auto|prepend|chain|disabled].
|
429
|
+
# instrumentation.sinatra: auto
|
430
|
+
|
431
|
+
# Controls auto-instrumentation of Tilt at start up.
|
432
|
+
# May be one of [auto|prepend|chain|disabled].
|
433
|
+
# instrumentation.tilt: auto
|
434
|
+
|
435
|
+
# Controls auto-instrumentation of Typhoeus at start up.
|
436
|
+
# May be one of [auto|prepend|chain|disabled].
|
437
|
+
# instrumentation.typhoeus: auto
|
438
|
+
|
439
|
+
# Controls auto-instrumentation of the Thread class at start up to allow the agent to correctly nest spans inside of an asynchronous transaction.
|
440
|
+
# May be one of [auto|prepend|chain|disabled].
|
441
|
+
# instrumentation.thread: auto
|
442
|
+
|
443
|
+
# Controls auto-instrumentation of the Thread class at start up to automatically add tracing to all Threads created in the application.
|
444
|
+
# instrumentation.thread.tracing: true
|
445
|
+
|
446
|
+
# Controls auto-instrumentation of gRPC clients at start up.
|
447
|
+
# May be one of [auto|prepend|chain|disabled].
|
448
|
+
# instrumentation.grpc_client: auto
|
449
|
+
|
450
|
+
# Controls auto-instrumentation of gRPC servers at start up.
|
451
|
+
# May be one of [auto|prepend|chain|disabled].
|
452
|
+
# instrumentation.grpc_server: auto
|
453
|
+
|
454
|
+
# Specifies a list of hostname patterns separated by commas that will match
|
455
|
+
# gRPC hostnames that traffic is to be ignored by New Relic for.
|
456
|
+
# New Relic's gRPC client instrumentation will ignore traffic streamed to a
|
457
|
+
# host matching any of these patterns, and New Relic's gRPC server
|
458
|
+
# instrumentation will ignore traffic for a server running on a host whose
|
459
|
+
# hostname matches any of these patterns. By default, no traffic is ignored
|
460
|
+
# when gRPC instrumentation is itself enabled.
|
461
|
+
# For example, "private.com$,exception.*"
|
462
|
+
# instrumentation.grpc.host_denylist: ""
|
463
|
+
|
464
|
+
# A dictionary of label names and values that will be applied to the data sent
|
465
|
+
# from this agent. May also be expressed as a semicolon-delimited ; string of
|
466
|
+
# colon-separated : pairs.
|
467
|
+
# For example,<var>Server</var>:<var>One</var>;<var>Data Center</var>:<var>Primary</var>.
|
468
|
+
# labels: ""
|
469
|
+
|
470
|
+
# Defines a name for the log file.
|
471
|
+
# log_file_name: "newrelic_agent.log"
|
472
|
+
|
473
|
+
# Defines a path to the agent log file, excluding the filename.
|
474
|
+
# log_file_path: "log/"
|
475
|
+
|
476
|
+
# Specifies a marshaller for transmitting data to the New Relic collector.
|
477
|
+
# Currently json is the only valid value for this setting.
|
478
|
+
# marshaller: json
|
479
|
+
|
480
|
+
# If true, the agent will collect metadata about messages and attach them as
|
481
|
+
# segment parameters.
|
482
|
+
# message_tracer.segment_parameters.enabled: true
|
483
|
+
|
484
|
+
# If true, the agent captures Mongo queries in transaction traces.
|
485
|
+
# mongo.capture_queries: true
|
486
|
+
|
487
|
+
# If true, the agent obfuscates Mongo queries in transaction traces.
|
488
|
+
# mongo.obfuscate_queries: true
|
489
|
+
|
490
|
+
# If true, the agent captures Elasticsearch queries in transaction traces.
|
491
|
+
# elasticsearch.capture_queries: true
|
492
|
+
|
493
|
+
# If true, the agent obfuscates Elasticsearch queries in transaction traces.
|
494
|
+
# elasticsearch.obfuscate_queries: true
|
495
|
+
|
496
|
+
# When true, the agent transmits data about your app to the New Relic collector.
|
497
|
+
# monitor_mode: true
|
498
|
+
|
499
|
+
# If true, uses Module#prepend rather than alias_method for Active Record
|
500
|
+
# instrumentation.
|
501
|
+
# prepend_active_record_instrumentation: false
|
502
|
+
|
503
|
+
# Specify a custom host name for display in the New Relic UI
|
504
|
+
# Be be aware that you cannot rename a hostname, so please rename
|
505
|
+
# process_host.display_name: "default hostname"
|
506
|
+
|
507
|
+
# Defines a host for communicating with the New Relic collector via a proxy
|
508
|
+
# server.
|
509
|
+
# proxy_host: nil
|
510
|
+
|
511
|
+
# Defines a password for communicating with the New Relic collector via a proxy
|
512
|
+
# server.
|
513
|
+
# proxy_pass: nil
|
514
|
+
|
515
|
+
# Defines a port for communicating with the New Relic collector via a proxy
|
516
|
+
# server.
|
517
|
+
# proxy_port: nil
|
518
|
+
|
519
|
+
# Defines a user for communicating with the New Relic collector via a proxy
|
520
|
+
# server.
|
521
|
+
# proxy_user: nil
|
522
|
+
|
523
|
+
# Timeout for waiting on connect to complete before a rake task
|
524
|
+
# rake.connect_timeout: 10
|
525
|
+
|
526
|
+
# Specify an array of Rake tasks to automatically instrument.
|
527
|
+
# This configuration option converts the Array to a RegEx list.
|
528
|
+
# If you'd like to allow all tasks by default, use `rake.tasks: [.+]`.
|
529
|
+
# Rake tasks will not be instrumented unless they're added to this list.
|
530
|
+
# For more information, visit the (New Relic Rake Instrumentation docs)[/docs/apm/agents/ruby-agent/background-jobs/rake-instrumentation].
|
531
|
+
# rake.tasks: []
|
532
|
+
|
533
|
+
# Define transactions you want the agent to ignore, by specifying a list of
|
534
|
+
# patterns matching the URI you want to ignore.
|
535
|
+
# rules.ignore_url_regexes: []
|
536
|
+
|
537
|
+
# Applies Language Agent Security Policy settings.
|
538
|
+
# security_policies_token: ""
|
539
|
+
|
540
|
+
# If true, enables the exit handler that sends data to the New Relic collector
|
541
|
+
# before shutting down.
|
542
|
+
# send_data_on_exit: true
|
543
|
+
|
544
|
+
# If true, the agent collects slow SQL queries.
|
545
|
+
# slow_sql.enabled: false
|
546
|
+
|
547
|
+
# If true, the agent collects explain plans in slow SQL queries. If this setting
|
548
|
+
# is omitted, the transaction_tracer.explain.enabled setting will be applied as
|
549
|
+
# the default setting for explain plans in slow SQL as well.
|
550
|
+
# slow_sql.explain_enabled: false
|
551
|
+
|
552
|
+
# Specify a threshold in seconds. The agent collects slow SQL queries and
|
553
|
+
# explain plans that exceed this threshold.
|
554
|
+
# slow_sql.explain_threshold: 1.0
|
555
|
+
|
556
|
+
# Defines an obfuscation level for slow SQL queries.
|
557
|
+
# Valid options are obfuscated, raw, or none.
|
558
|
+
# slow_sql.record_sql: none
|
559
|
+
|
560
|
+
# Generate a longer sql_id for slow SQL traces. sql_id is used for aggregation
|
561
|
+
# of similar queries.
|
562
|
+
# slow_sql.use_longer_sql_id: false
|
563
|
+
|
564
|
+
# If true, the agent captures attributes on span events.
|
565
|
+
# span_events_attributes.enabled: true
|
566
|
+
|
567
|
+
# Defines the maximum number of span events reported from a single harvest.
|
568
|
+
# This can be any integer between 1 and 10000. Increasing this value may impact
|
569
|
+
# memory usage.
|
570
|
+
# span_events.max_samples_stored: 2000
|
571
|
+
|
572
|
+
# Prefix of attributes to exclude from span events. Allows * as wildcard at end.
|
573
|
+
# span_events.attributes.exclude: []
|
574
|
+
|
575
|
+
# Prefix of attributes to include on span events. Allows * as wildcard at end.
|
576
|
+
# span_events.attributes.include: []
|
577
|
+
|
578
|
+
# If true, enables span event sampling.
|
579
|
+
# span_events.enabled: true
|
580
|
+
|
581
|
+
# Sets the maximum number of span events to buffer when streaming to the trace
|
582
|
+
# observer.
|
583
|
+
# span_events.queue_size: 10000
|
584
|
+
|
585
|
+
# Specify a list of exceptions you do not want the agent to strip when
|
586
|
+
# strip_exception_messages is true. Separate exceptions with a comma. For
|
587
|
+
# example, "ImportantException,PreserveMessageException".
|
588
|
+
# strip_exception_messages.allowed_classes: ""
|
589
|
+
|
590
|
+
# If true, the agent strips messages from all exceptions except those in the
|
591
|
+
# allowlist. Enabled automatically in high security mode.
|
592
|
+
# strip_exception_messages.enabled: true
|
593
|
+
|
594
|
+
# When set to true, forces a synchronous connection to the New Relic collector
|
595
|
+
# during application startup. For very short-lived processes, this helps ensure # the New Relic agent has time to report.
|
596
|
+
# sync_startup: false
|
597
|
+
|
598
|
+
# If true, enables use of the thread profiler.
|
599
|
+
# thread_profiler.enabled: false
|
600
|
+
|
601
|
+
# Defines the maximum number of seconds the agent should spend attempting to
|
602
|
+
# connect to the collector.
|
603
|
+
# timeout: 120
|
604
|
+
|
605
|
+
# If true, the agent captures attributes from transaction events.
|
606
|
+
# transaction_events_attributes.enabled: false
|
607
|
+
|
608
|
+
# Prefix of attributes to exclude from transaction events.
|
609
|
+
# Allows * as wildcard at end.
|
610
|
+
# transaction_events.attributes.exclude: []
|
611
|
+
|
612
|
+
# Prefix of attributes to include in transaction events.
|
613
|
+
# Allows * as wildcard at end.
|
614
|
+
# transaction_events.attributes.include: []
|
615
|
+
|
616
|
+
# If true, the agent captures attributes on transaction segments.
|
617
|
+
# transaction_segments_attributes.enabled: true
|
618
|
+
|
619
|
+
# Prefix of attributes to exclude from transaction segments.
|
620
|
+
# Allows * as wildcard at end.
|
621
|
+
# transaction_segments.attributes.exclude: []
|
622
|
+
|
623
|
+
# Prefix of attributes to include on transaction segments.
|
624
|
+
# Allows * as wildcard at end.
|
625
|
+
# transaction_segments.attributes.include: []
|
626
|
+
|
627
|
+
# If true, the agent captures attributes from transaction traces.
|
628
|
+
# transaction_tracer.attributes.enabled: false
|
629
|
+
|
630
|
+
# Prefix of attributes to exclude from transaction traces.
|
631
|
+
# Allows * as wildcard at end.
|
632
|
+
# transaction_tracer.attributes.exclude: []
|
633
|
+
|
634
|
+
# Prefix of attributes to include in transaction traces.
|
635
|
+
# Allows * as wildcard at end.
|
636
|
+
# transaction_tracer.attributes.include: []
|
637
|
+
|
638
|
+
# If true, enables collection of transaction traces.
|
639
|
+
# transaction_tracer.enabled: true
|
640
|
+
|
641
|
+
# Threshold (in seconds) above which the agent will collect explain plans.
|
642
|
+
# Relevant only when explain.enabled is true.
|
643
|
+
# transaction_tracer.explain_threshold: 0.5
|
644
|
+
|
645
|
+
# If true, enables the collection of explain plans in transaction traces.
|
646
|
+
# This setting will also apply to explain plans in slow SQL traces if
|
647
|
+
# slow_sql.explain enabled is not set separately.
|
648
|
+
# transaction_tracer.explain.enabled: true
|
649
|
+
|
650
|
+
# Maximum number of transaction trace nodes to record in a single transaction
|
651
|
+
# trace.
|
652
|
+
# transaction_tracer.limit_segments: 4000
|
653
|
+
|
654
|
+
# If true, the agent records Redis command arguments in transaction traces.
|
655
|
+
# transaction_tracer.record_redis_arguments: false
|
656
|
+
|
657
|
+
# Obfuscation level for SQL queries reported in transaction trace nodes.
|
658
|
+
# By default, this is set to obfuscated, which strips out the numeric and string
|
659
|
+
# literals. If you do not want the agent to capture query information, set this
|
660
|
+
# to 'none'. If you want the agent to capture all query information in its
|
661
|
+
# original form, set this to 'raw'. When you enable high security mode this is
|
662
|
+
# automatically set to 'obfuscated'
|
663
|
+
# transaction_tracer.record_sql: 'obfuscated'
|
664
|
+
|
665
|
+
# Specify a threshold in seconds. The agent includes stack traces in transaction
|
666
|
+
# trace nodes when the stack trace duration exceeds this threshold.
|
667
|
+
# transaction_tracer.stack_trace_threshold: 0.5
|
668
|
+
|
669
|
+
# Specify a threshold in seconds. Transactions with a duration longer than this
|
670
|
+
# threshold are eligible for transaction traces. Specify a float value or the
|
671
|
+
# string apdex_f.
|
672
|
+
# transaction_tracer.transaction_threshold: 1.0
|
673
|
+
|
674
|
+
# If true, the agent automatically detects that it is running in an AWS
|
675
|
+
# environment.
|
676
|
+
# utilization.detect_aws: true
|
677
|
+
|
678
|
+
# If true, the agent automatically detects that it is running in an Azure
|
679
|
+
# environment.
|
680
|
+
# utilization.detect_azure: true
|
681
|
+
|
682
|
+
# If true, the agent automatically detects that it is running in Docker.
|
683
|
+
# utilization.detect_docker: true
|
684
|
+
|
685
|
+
# If true, the agent automatically detects that it is running in an Google Cloud
|
686
|
+
# Platform environment.
|
687
|
+
# utilization.detect_gcp: true
|
688
|
+
|
689
|
+
# If true, the agent automatically detects that it is running in Kubernetes.
|
690
|
+
# utilization.detect_kubernetes: true
|
691
|
+
|
692
|
+
# If true, the agent automatically detects that it is running in a Pivotal Cloud Foundry environment.
|
693
|
+
# utilization.detect_pcf: true
|
25
694
|
|
26
695
|
# Environment-specific settings are in this section.
|
27
696
|
# RAILS_ENV or RACK_ENV (as appropriate) is used to determine the environment.
|