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
@@ -1,10 +1,11 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# This file is distributed under New Relic's license terms.
|
3
|
-
# See https://github.com/newrelic/
|
2
|
+
# See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
|
3
|
+
# frozen_string_literal: true
|
4
4
|
|
5
5
|
require 'new_relic/agent/transaction'
|
6
6
|
require 'new_relic/agent/instrumentation/queue_time'
|
7
7
|
require 'new_relic/agent/instrumentation/ignore_actions'
|
8
|
+
|
8
9
|
module NewRelic
|
9
10
|
module Agent
|
10
11
|
# @api public
|
@@ -22,7 +23,6 @@ module NewRelic
|
|
22
23
|
# @api public
|
23
24
|
#
|
24
25
|
module ControllerInstrumentation
|
25
|
-
|
26
26
|
def self.included(clazz) # :nodoc:
|
27
27
|
clazz.extend(ClassMethods)
|
28
28
|
end
|
@@ -30,7 +30,9 @@ module NewRelic
|
|
30
30
|
# This module is for importing stubs when the agent is disabled
|
31
31
|
module ClassMethodsShim # :nodoc:
|
32
32
|
def newrelic_ignore(*args); end
|
33
|
+
|
33
34
|
def newrelic_ignore_apdex(*args); end
|
35
|
+
|
34
36
|
def newrelic_ignore_enduser(*args); end
|
35
37
|
end
|
36
38
|
|
@@ -38,14 +40,16 @@ module NewRelic
|
|
38
40
|
def self.included(clazz)
|
39
41
|
clazz.extend(ClassMethodsShim)
|
40
42
|
end
|
43
|
+
|
41
44
|
def new_relic_trace_controller_action(*args); yield; end
|
45
|
+
|
42
46
|
def perform_action_with_newrelic_trace(*args); yield; end
|
43
47
|
end
|
44
48
|
|
45
|
-
NR_DO_NOT_TRACE_KEY
|
46
|
-
NR_IGNORE_APDEX_KEY
|
49
|
+
NR_DO_NOT_TRACE_KEY = :'@do_not_trace'
|
50
|
+
NR_IGNORE_APDEX_KEY = :'@ignore_apdex'
|
47
51
|
NR_IGNORE_ENDUSER_KEY = :'@ignore_enduser'
|
48
|
-
NR_DEFAULT_OPTIONS
|
52
|
+
NR_DEFAULT_OPTIONS = NewRelic::EMPTY_HASH
|
49
53
|
|
50
54
|
# @api public
|
51
55
|
module ClassMethods
|
@@ -54,32 +58,33 @@ module NewRelic
|
|
54
58
|
#
|
55
59
|
# @api public
|
56
60
|
#
|
57
|
-
def newrelic_ignore(specifiers={})
|
61
|
+
def newrelic_ignore(specifiers = {})
|
58
62
|
NewRelic::Agent.record_api_supportability_metric(:newrelic_ignore)
|
59
63
|
newrelic_ignore_aspect(NR_DO_NOT_TRACE_KEY, specifiers)
|
60
64
|
end
|
65
|
+
|
61
66
|
# Have NewRelic omit apdex measurements on the given actions. Typically used for
|
62
67
|
# actions that are not user facing or that skew your overall apdex measurement.
|
63
68
|
# Accepts :except and :only options, as with #newrelic_ignore.
|
64
69
|
#
|
65
70
|
# @api public
|
66
71
|
#
|
67
|
-
def newrelic_ignore_apdex(specifiers={})
|
72
|
+
def newrelic_ignore_apdex(specifiers = {})
|
68
73
|
NewRelic::Agent.record_api_supportability_metric(:newrelic_ignore_apdex)
|
69
74
|
newrelic_ignore_aspect(NR_IGNORE_APDEX_KEY, specifiers)
|
70
75
|
end
|
71
76
|
|
72
77
|
# @api public
|
73
|
-
def newrelic_ignore_enduser(specifiers={})
|
78
|
+
def newrelic_ignore_enduser(specifiers = {})
|
74
79
|
NewRelic::Agent.record_api_supportability_metric(:newrelic_ignore_enduser)
|
75
80
|
newrelic_ignore_aspect(NR_IGNORE_ENDUSER_KEY, specifiers)
|
76
81
|
end
|
77
82
|
|
78
|
-
def newrelic_ignore_aspect(property, specifiers={}) # :nodoc:
|
83
|
+
def newrelic_ignore_aspect(property, specifiers = {}) # :nodoc:
|
79
84
|
if specifiers.empty?
|
80
|
-
self.newrelic_write_attr
|
81
|
-
elsif !
|
82
|
-
::NewRelic::Agent.logger.error
|
85
|
+
self.newrelic_write_attr(property, true)
|
86
|
+
elsif !(Hash === specifiers)
|
87
|
+
::NewRelic::Agent.logger.error("newrelic_#{property} takes an optional hash with :only and :except lists of actions (illegal argument type '#{specifiers.class}')")
|
83
88
|
else
|
84
89
|
# symbolize the incoming values
|
85
90
|
specifiers = specifiers.inject({}) do |memo, (key, values)|
|
@@ -90,7 +95,7 @@ module NewRelic
|
|
90
95
|
end
|
91
96
|
memo
|
92
97
|
end
|
93
|
-
self.newrelic_write_attr
|
98
|
+
self.newrelic_write_attr(property, specifiers)
|
94
99
|
end
|
95
100
|
end
|
96
101
|
|
@@ -158,13 +163,9 @@ module NewRelic
|
|
158
163
|
#
|
159
164
|
# @api public
|
160
165
|
#
|
161
|
-
def add_transaction_tracer(method, options={})
|
166
|
+
def add_transaction_tracer(method, options = {})
|
162
167
|
NewRelic::Agent.record_api_supportability_metric(:add_transaction_tracer)
|
163
168
|
|
164
|
-
# The metric path:
|
165
|
-
options[:name] ||= method.to_s
|
166
|
-
|
167
|
-
argument_list = generate_argument_list(options)
|
168
169
|
traced_method, punctuation = parse_punctuation(method)
|
169
170
|
with_method_name, without_method_name = build_method_names(traced_method, punctuation)
|
170
171
|
|
@@ -173,20 +174,27 @@ module NewRelic
|
|
173
174
|
return
|
174
175
|
end
|
175
176
|
|
176
|
-
|
177
|
+
# The metric path:
|
178
|
+
options[:name] ||= method.to_s
|
179
|
+
|
180
|
+
code_info = NewRelic::Agent::MethodTracerHelpers.code_information(self, method)
|
181
|
+
argument_list = generate_argument_list(options.merge(code_info))
|
182
|
+
|
183
|
+
class_eval(<<~EOC)
|
177
184
|
def #{with_method_name}(*args, &block)
|
178
185
|
perform_action_with_newrelic_trace(#{argument_list.join(',')}) do
|
179
186
|
#{without_method_name}(*args, &block)
|
180
187
|
end
|
181
188
|
end
|
189
|
+
ruby2_keywords(:#{with_method_name}) if respond_to?(:ruby2_keywords, true)
|
182
190
|
EOC
|
183
191
|
|
184
|
-
visibility = NewRelic::Helper.instance_method_visibility
|
192
|
+
visibility = NewRelic::Helper.instance_method_visibility(self, method)
|
185
193
|
|
186
|
-
alias_method
|
187
|
-
alias_method
|
188
|
-
send
|
189
|
-
send
|
194
|
+
alias_method(without_method_name, method.to_s)
|
195
|
+
alias_method(method.to_s, with_method_name)
|
196
|
+
send(visibility, method)
|
197
|
+
send(visibility, with_method_name)
|
190
198
|
::NewRelic::Agent.logger.debug("Traced transaction: class = #{self.name}, method = #{method.to_s}, options = #{options.inspect}")
|
191
199
|
end
|
192
200
|
|
@@ -201,52 +209,52 @@ module NewRelic
|
|
201
209
|
elsif key == :params
|
202
210
|
value.to_s
|
203
211
|
else
|
204
|
-
%Q
|
212
|
+
%Q("#{value.to_s}")
|
205
213
|
end
|
206
214
|
|
207
|
-
%Q
|
215
|
+
%Q(:#{key} => #{value})
|
208
216
|
end
|
209
217
|
end
|
210
218
|
|
211
219
|
def build_method_names(traced_method, punctuation)
|
212
|
-
[
|
213
|
-
"#{traced_method.to_s}_without_newrelic_transaction_trace#{punctuation}"
|
220
|
+
["#{traced_method.to_s}_with_newrelic_transaction_trace#{punctuation}",
|
221
|
+
"#{traced_method.to_s}_without_newrelic_transaction_trace#{punctuation}"]
|
214
222
|
end
|
215
223
|
|
216
224
|
def already_added_transaction_tracer?(target, with_method_name)
|
217
|
-
|
218
|
-
true
|
219
|
-
else
|
220
|
-
false
|
221
|
-
end
|
225
|
+
NewRelic::Helper.instance_methods_include?(target, with_method_name)
|
222
226
|
end
|
223
227
|
end
|
224
228
|
|
225
229
|
# @!parse extend ClassMethods
|
226
230
|
|
227
231
|
class TransactionNamer
|
228
|
-
def self.name_for(txn, traced_obj, category, options={})
|
232
|
+
def self.name_for(txn, traced_obj, category, options = {})
|
233
|
+
return options[:transaction_name] if options[:transaction_name]
|
234
|
+
|
229
235
|
"#{prefix_for_category(txn, category)}#{path_name(traced_obj, options)}"
|
230
236
|
end
|
231
237
|
|
232
238
|
def self.prefix_for_category(txn, category = nil)
|
233
239
|
category ||= (txn && txn.category)
|
234
240
|
case category
|
235
|
-
when :controller
|
236
|
-
when :
|
237
|
-
when :
|
238
|
-
when :
|
239
|
-
when :
|
240
|
-
when :
|
241
|
-
when :
|
242
|
-
when :
|
243
|
-
when :
|
244
|
-
when :
|
241
|
+
when :controller then ::NewRelic::Agent::Transaction::CONTROLLER_PREFIX
|
242
|
+
when :web then ::NewRelic::Agent::Transaction::CONTROLLER_PREFIX
|
243
|
+
when :task then ::NewRelic::Agent::Transaction::TASK_PREFIX
|
244
|
+
when :background then ::NewRelic::Agent::Transaction::TASK_PREFIX
|
245
|
+
when :rack then ::NewRelic::Agent::Transaction::RACK_PREFIX
|
246
|
+
when :uri then ::NewRelic::Agent::Transaction::CONTROLLER_PREFIX
|
247
|
+
when :sinatra then ::NewRelic::Agent::Transaction::SINATRA_PREFIX
|
248
|
+
when :middleware then ::NewRelic::Agent::Transaction::MIDDLEWARE_PREFIX
|
249
|
+
when :grape then ::NewRelic::Agent::Transaction::GRAPE_PREFIX
|
250
|
+
when :rake then ::NewRelic::Agent::Transaction::RAKE_PREFIX
|
251
|
+
when :action_cable then ::NewRelic::Agent::Transaction::ACTION_CABLE_PREFIX
|
252
|
+
when :message then ::NewRelic::Agent::Transaction::MESSAGE_PREFIX
|
245
253
|
else "#{category.to_s}/" # for internal use only
|
246
254
|
end
|
247
255
|
end
|
248
256
|
|
249
|
-
def self.path_name(traced_obj, options={})
|
257
|
+
def self.path_name(traced_obj, options = {})
|
250
258
|
return options[:path] if options[:path]
|
251
259
|
|
252
260
|
class_name = class_name(traced_obj, options)
|
@@ -263,9 +271,10 @@ module NewRelic
|
|
263
271
|
end
|
264
272
|
end
|
265
273
|
|
266
|
-
def self.class_name(traced_obj, options={})
|
274
|
+
def self.class_name(traced_obj, options = {})
|
267
275
|
return options[:class_name] if options[:class_name]
|
268
|
-
|
276
|
+
|
277
|
+
if traced_obj.is_a?(Class) || traced_obj.is_a?(Module)
|
269
278
|
traced_obj.name
|
270
279
|
else
|
271
280
|
traced_obj.class.name
|
@@ -274,7 +283,7 @@ module NewRelic
|
|
274
283
|
end
|
275
284
|
|
276
285
|
# Yield to the given block with NewRelic tracing. Used by
|
277
|
-
# default instrumentation on controller actions in Rails
|
286
|
+
# default instrumentation on controller actions in Rails.
|
278
287
|
# But it can also be used in custom instrumentation of controller
|
279
288
|
# methods and background tasks.
|
280
289
|
#
|
@@ -331,7 +340,7 @@ module NewRelic
|
|
331
340
|
#
|
332
341
|
# Seldomly used options:
|
333
342
|
#
|
334
|
-
# * <tt>:class_name =>
|
343
|
+
# * <tt>:class_name => Class.name</tt> is used to override the name
|
335
344
|
# of the class when used inside the metric name. Default is the
|
336
345
|
# current class.
|
337
346
|
# * <tt>:path => metric_path</tt> is *deprecated* in the public API. It
|
@@ -342,9 +351,9 @@ module NewRelic
|
|
342
351
|
#
|
343
352
|
# @api public
|
344
353
|
#
|
345
|
-
def perform_action_with_newrelic_trace(*args, &block) #THREAD_LOCAL_ACCESS
|
354
|
+
def perform_action_with_newrelic_trace(*args, &block) # THREAD_LOCAL_ACCESS
|
346
355
|
NewRelic::Agent.record_api_supportability_metric(:perform_action_with_newrelic_trace)
|
347
|
-
state = NewRelic::Agent::
|
356
|
+
state = NewRelic::Agent::Tracer.state
|
348
357
|
request = newrelic_request(args)
|
349
358
|
queue_start_time = detect_queue_start_time(request)
|
350
359
|
|
@@ -360,11 +369,15 @@ module NewRelic
|
|
360
369
|
# the *args method signature to ensure backwards compatibility.
|
361
370
|
|
362
371
|
trace_options = args.last.is_a?(Hash) ? args.last : NR_DEFAULT_OPTIONS
|
363
|
-
category
|
364
|
-
txn_options
|
372
|
+
category = trace_options[:category] || :controller
|
373
|
+
txn_options = create_transaction_options(trace_options, category, state, queue_start_time)
|
365
374
|
|
366
375
|
begin
|
367
|
-
|
376
|
+
finishable = Tracer.start_transaction_or_segment(
|
377
|
+
name: txn_options[:transaction_name],
|
378
|
+
category: category,
|
379
|
+
options: txn_options
|
380
|
+
)
|
368
381
|
|
369
382
|
begin
|
370
383
|
yield
|
@@ -372,9 +385,8 @@ module NewRelic
|
|
372
385
|
NewRelic::Agent.notice_error(e)
|
373
386
|
raise
|
374
387
|
end
|
375
|
-
|
376
388
|
ensure
|
377
|
-
|
389
|
+
finishable.finish if finishable
|
378
390
|
end
|
379
391
|
end
|
380
392
|
|
@@ -404,14 +416,14 @@ module NewRelic
|
|
404
416
|
end
|
405
417
|
end
|
406
418
|
|
407
|
-
#
|
419
|
+
# overridable method to determine whether to trace an action
|
408
420
|
# or not - you may override this in your controller and supply
|
409
421
|
# your own logic for ignoring transactions.
|
410
422
|
def do_not_trace?
|
411
423
|
_is_filtered?(NR_DO_NOT_TRACE_KEY)
|
412
424
|
end
|
413
425
|
|
414
|
-
#
|
426
|
+
# overridable method to determine whether to trace an action
|
415
427
|
# for purposes of apdex measurement - you can use this to
|
416
428
|
# ignore things like api calls or other fast non-user-facing
|
417
429
|
# actions
|
@@ -427,7 +439,7 @@ module NewRelic
|
|
427
439
|
|
428
440
|
def create_transaction_options(trace_options, category, state, queue_start_time)
|
429
441
|
txn_options = {}
|
430
|
-
txn_options[:request]
|
442
|
+
txn_options[:request] = trace_options[:request]
|
431
443
|
txn_options[:request] ||= request if respond_to?(:request) rescue nil
|
432
444
|
# params should have been filtered before calling perform_action_with_newrelic_trace
|
433
445
|
txn_options[:filtered_params] = trace_options[:params]
|
@@ -435,6 +447,9 @@ module NewRelic
|
|
435
447
|
txn_options[:apdex_start_time] = queue_start_time
|
436
448
|
txn_options[:ignore_apdex] = ignore_apdex?
|
437
449
|
txn_options[:ignore_enduser] = ignore_enduser?
|
450
|
+
NewRelic::Agent::MethodTracerHelpers::SOURCE_CODE_INFORMATION_PARAMETERS.each do |parameter|
|
451
|
+
txn_options[parameter] = trace_options[parameter]
|
452
|
+
end
|
438
453
|
txn_options
|
439
454
|
end
|
440
455
|
|
@@ -450,7 +465,8 @@ module NewRelic
|
|
450
465
|
NewRelic::Agent::Instrumentation::IgnoreActions.is_filtered?(
|
451
466
|
key,
|
452
467
|
self.class,
|
453
|
-
name
|
468
|
+
name
|
469
|
+
)
|
454
470
|
end
|
455
471
|
|
456
472
|
def detect_queue_start_time(request)
|
@@ -0,0 +1,91 @@
|
|
1
|
+
# This file is distributed under New Relic's license terms.
|
2
|
+
# See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
|
3
|
+
# frozen_string_literal: true
|
4
|
+
|
5
|
+
require_relative 'instrumentation'
|
6
|
+
|
7
|
+
module NewRelic::Agent::Instrumentation
|
8
|
+
module Curb
|
9
|
+
module Chain
|
10
|
+
def self.instrument!
|
11
|
+
Curl::Easy.class_eval do
|
12
|
+
include NewRelic::Agent::Instrumentation::Curb::Easy
|
13
|
+
|
14
|
+
def http_head_with_newrelic(*args, &blk)
|
15
|
+
http_head_with_tracing { http_head_without_newrelic(*args, &blk) }
|
16
|
+
end
|
17
|
+
|
18
|
+
alias_method(:http_head_without_newrelic, :http_head)
|
19
|
+
alias_method(:http_head, :http_head_with_newrelic)
|
20
|
+
|
21
|
+
def http_post_with_newrelic(*args, &blk)
|
22
|
+
http_post_with_tracing { http_post_without_newrelic(*args, &blk) }
|
23
|
+
end
|
24
|
+
|
25
|
+
alias_method(:http_post_without_newrelic, :http_post)
|
26
|
+
alias_method(:http_post, :http_post_with_newrelic)
|
27
|
+
|
28
|
+
def http_put_with_newrelic(*args, &blk)
|
29
|
+
http_put_with_tracing { http_put_without_newrelic(*args, &blk) }
|
30
|
+
end
|
31
|
+
|
32
|
+
alias_method(:http_put_without_newrelic, :http_put)
|
33
|
+
alias_method(:http_put, :http_put_with_newrelic)
|
34
|
+
|
35
|
+
# Hook the #http method to set the verb.
|
36
|
+
def http_with_newrelic(verb)
|
37
|
+
http_with_tracing(verb) { http_without_newrelic(verb) }
|
38
|
+
end
|
39
|
+
|
40
|
+
alias_method(:http_without_newrelic, :http)
|
41
|
+
alias_method(:http, :http_with_newrelic)
|
42
|
+
|
43
|
+
# Hook the #perform method to mark the request as non-parallel.
|
44
|
+
def perform_with_newrelic
|
45
|
+
perform_with_tracing { perform_without_newrelic }
|
46
|
+
end
|
47
|
+
|
48
|
+
alias_method(:perform_without_newrelic, :perform)
|
49
|
+
alias_method(:perform, :perform_with_newrelic)
|
50
|
+
|
51
|
+
# Record the HTTP verb for future #perform calls
|
52
|
+
def method_with_newrelic(verb)
|
53
|
+
method_with_tracing(verb) { method_without_newrelic(verb) }
|
54
|
+
end
|
55
|
+
|
56
|
+
alias_method(:method_without_newrelic, :method)
|
57
|
+
alias_method(:method, :method_with_newrelic)
|
58
|
+
|
59
|
+
# We override this method in order to ensure access to header_str even
|
60
|
+
# though we use an on_header callback
|
61
|
+
def header_str_with_newrelic
|
62
|
+
header_str_with_tracing { header_str_without_newrelic }
|
63
|
+
end
|
64
|
+
|
65
|
+
alias_method(:header_str_without_newrelic, :header_str)
|
66
|
+
alias_method(:header_str, :header_str_with_newrelic)
|
67
|
+
end
|
68
|
+
|
69
|
+
Curl::Multi.class_eval do
|
70
|
+
include NewRelic::Agent::Instrumentation::Curb::Multi
|
71
|
+
|
72
|
+
# Add CAT with callbacks if the request is serial
|
73
|
+
def add_with_newrelic(curl)
|
74
|
+
add_with_tracing(curl) { add_without_newrelic(curl) }
|
75
|
+
end
|
76
|
+
|
77
|
+
alias_method(:add_without_newrelic, :add)
|
78
|
+
alias_method(:add, :add_with_newrelic)
|
79
|
+
|
80
|
+
# Trace as an External/Multiple call if the first request isn't serial.
|
81
|
+
def perform_with_newrelic(&blk)
|
82
|
+
perform_with_tracing { perform_without_newrelic(&blk) }
|
83
|
+
end
|
84
|
+
|
85
|
+
alias_method(:perform_without_newrelic, :perform)
|
86
|
+
alias_method(:perform, :perform_with_newrelic)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
91
|
+
end
|
@@ -0,0 +1,221 @@
|
|
1
|
+
# This file is distributed under New Relic's license terms.
|
2
|
+
# See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
|
3
|
+
# frozen_string_literal: true
|
4
|
+
|
5
|
+
module NewRelic
|
6
|
+
module Agent
|
7
|
+
module Instrumentation
|
8
|
+
module Curb
|
9
|
+
module Easy
|
10
|
+
attr_accessor :_nr_instrumented,
|
11
|
+
:_nr_http_verb,
|
12
|
+
:_nr_header_str,
|
13
|
+
:_nr_original_on_header,
|
14
|
+
:_nr_original_on_complete,
|
15
|
+
:_nr_original_on_failure,
|
16
|
+
:_nr_serial
|
17
|
+
|
18
|
+
# We have to hook these three methods separately, as they don't use
|
19
|
+
# Curl::Easy#http
|
20
|
+
def http_head_with_tracing
|
21
|
+
self._nr_http_verb = :HEAD
|
22
|
+
yield
|
23
|
+
end
|
24
|
+
|
25
|
+
def http_post_with_tracing
|
26
|
+
self._nr_http_verb = :POST
|
27
|
+
yield
|
28
|
+
end
|
29
|
+
|
30
|
+
def http_put_with_tracing
|
31
|
+
self._nr_http_verb = :PUT
|
32
|
+
yield
|
33
|
+
end
|
34
|
+
|
35
|
+
# Hook the #http method to set the verb.
|
36
|
+
def http_with_tracing(verb)
|
37
|
+
self._nr_http_verb = verb.to_s.upcase
|
38
|
+
yield
|
39
|
+
end
|
40
|
+
|
41
|
+
# Hook the #perform method to mark the request as non-parallel.
|
42
|
+
def perform_with_tracing
|
43
|
+
self._nr_http_verb ||= :GET
|
44
|
+
self._nr_serial = true
|
45
|
+
yield
|
46
|
+
end
|
47
|
+
|
48
|
+
# Record the HTTP verb for future #perform calls
|
49
|
+
def method_with_tracing(verb)
|
50
|
+
self._nr_http_verb = verb.upcase
|
51
|
+
yield
|
52
|
+
end
|
53
|
+
|
54
|
+
# We override this method in order to ensure access to header_str even
|
55
|
+
# though we use an on_header callback
|
56
|
+
def header_str_with_tracing
|
57
|
+
if self._nr_serial
|
58
|
+
self._nr_header_str
|
59
|
+
else
|
60
|
+
# Since we didn't install a header callback for a non-serial request,
|
61
|
+
# just fall back to the original implementation.
|
62
|
+
yield
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
####################################################
|
67
|
+
|
68
|
+
module Multi
|
69
|
+
include NewRelic::Agent::MethodTracer
|
70
|
+
|
71
|
+
# Add CAT with callbacks if the request is serial
|
72
|
+
def add_with_tracing(curl)
|
73
|
+
if curl.respond_to?(:_nr_serial) && curl._nr_serial
|
74
|
+
hook_pending_request(curl) if NewRelic::Agent::Tracer.tracing_enabled?
|
75
|
+
end
|
76
|
+
|
77
|
+
return yield
|
78
|
+
end
|
79
|
+
|
80
|
+
# Trace as an External/Multiple call if the first request isn't serial.
|
81
|
+
def perform_with_tracing
|
82
|
+
return yield if first_request_is_serial?
|
83
|
+
|
84
|
+
trace_execution_scoped("External/Multiple/Curb::Multi/perform") do
|
85
|
+
yield
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
# Instrument the specified +request+ (a Curl::Easy object)
|
90
|
+
# and set up cross-application tracing if it's enabled.
|
91
|
+
def hook_pending_request(request)
|
92
|
+
wrapped_request, wrapped_response = wrap_request(request)
|
93
|
+
|
94
|
+
segment = NewRelic::Agent::Tracer.start_external_request_segment(
|
95
|
+
library: wrapped_request.type,
|
96
|
+
uri: wrapped_request.uri,
|
97
|
+
procedure: wrapped_request.method
|
98
|
+
)
|
99
|
+
|
100
|
+
segment.add_request_headers(wrapped_request)
|
101
|
+
|
102
|
+
# install all callbacks
|
103
|
+
unless request._nr_instrumented
|
104
|
+
install_header_callback(request, wrapped_response)
|
105
|
+
install_completion_callback(request, wrapped_response, segment)
|
106
|
+
install_failure_callback(request, wrapped_response, segment)
|
107
|
+
request._nr_instrumented = true
|
108
|
+
end
|
109
|
+
rescue => err
|
110
|
+
NewRelic::Agent.logger.error("Untrapped exception", err)
|
111
|
+
end
|
112
|
+
|
113
|
+
# Create request and response adapter objects for the specified +request+
|
114
|
+
# NOTE: Although strange to wrap request and response at once, it works
|
115
|
+
# because curb's callback mechanism updates the instantiated wrappers
|
116
|
+
# during the life-cycle of external request
|
117
|
+
def wrap_request(request)
|
118
|
+
return NewRelic::Agent::HTTPClients::CurbRequest.new(request),
|
119
|
+
NewRelic::Agent::HTTPClients::CurbResponse.new(request)
|
120
|
+
end
|
121
|
+
|
122
|
+
# Install a callback that will record the response headers
|
123
|
+
# to enable CAT linking
|
124
|
+
def install_header_callback(request, wrapped_response)
|
125
|
+
original_callback = request.on_header
|
126
|
+
request._nr_original_on_header = original_callback
|
127
|
+
request._nr_header_str = nil
|
128
|
+
request.on_header do |header_data|
|
129
|
+
if original_callback
|
130
|
+
original_callback.call(header_data)
|
131
|
+
else
|
132
|
+
wrapped_response.append_header_data(header_data)
|
133
|
+
header_data.length
|
134
|
+
end
|
135
|
+
end
|
136
|
+
end
|
137
|
+
|
138
|
+
# Install a callback that will finish the trace.
|
139
|
+
def install_completion_callback(request, wrapped_response, segment)
|
140
|
+
original_callback = request.on_complete
|
141
|
+
request._nr_original_on_complete = original_callback
|
142
|
+
request.on_complete do |finished_request|
|
143
|
+
begin
|
144
|
+
segment.process_response_headers(wrapped_response) if segment
|
145
|
+
ensure
|
146
|
+
::NewRelic::Agent::Transaction::Segment.finish(segment)
|
147
|
+
# Make sure the existing completion callback is run, and restore the
|
148
|
+
# on_complete callback to how it was before.
|
149
|
+
original_callback.call(finished_request) if original_callback
|
150
|
+
remove_instrumentation_callbacks(request)
|
151
|
+
end
|
152
|
+
end
|
153
|
+
end
|
154
|
+
|
155
|
+
# Install a callback that will fire on failures
|
156
|
+
# NOTE: on_failure is not always called, so we're not always
|
157
|
+
# unhooking the callback. No harm/no foul in production, but
|
158
|
+
# definitely something to beware of if debugging callback issues
|
159
|
+
# @__newrelic_original_callback exists to prevent infinitely chaining
|
160
|
+
# our on_failure callback hook.
|
161
|
+
def install_failure_callback(request, _wrapped_response, segment)
|
162
|
+
original_callback = request.on_failure
|
163
|
+
|
164
|
+
nr_original_callback = original_callback.instance_variable_get(:@__newrelic_original_callback)
|
165
|
+
original_callback = nr_original_callback || original_callback
|
166
|
+
|
167
|
+
request._nr_original_on_failure = original_callback
|
168
|
+
|
169
|
+
newrelic_callback = proc do |failed_request, error|
|
170
|
+
begin
|
171
|
+
if segment
|
172
|
+
noticeable_error = NewRelic::Agent::NoticeableError.new(error[0].name, error[-1])
|
173
|
+
segment.notice_error(noticeable_error)
|
174
|
+
end
|
175
|
+
ensure
|
176
|
+
original_callback.call(failed_request, error) if original_callback
|
177
|
+
remove_failure_callback(failed_request)
|
178
|
+
end
|
179
|
+
end
|
180
|
+
newrelic_callback.instance_variable_set(:@__newrelic_original_callback, original_callback)
|
181
|
+
|
182
|
+
request.on_failure(&newrelic_callback)
|
183
|
+
end
|
184
|
+
|
185
|
+
# on_failure callbacks cannot be removed in the on_complete
|
186
|
+
# callback where this method is invoked because on_complete
|
187
|
+
# fires before the on_failure!
|
188
|
+
def remove_instrumentation_callbacks(request)
|
189
|
+
request.on_complete(&request._nr_original_on_complete)
|
190
|
+
request.on_header(&request._nr_original_on_header)
|
191
|
+
request._nr_instrumented = false
|
192
|
+
end
|
193
|
+
|
194
|
+
# We execute customer's on_failure callback (if any) and
|
195
|
+
# uninstall our hook here since the on_complete callback
|
196
|
+
# fires before the on_failure callback.
|
197
|
+
def remove_failure_callback(request)
|
198
|
+
request.on_failure(&request._nr_original_on_failure)
|
199
|
+
end
|
200
|
+
|
201
|
+
private
|
202
|
+
|
203
|
+
def first_request_is_serial?
|
204
|
+
return false unless (first = self.requests.first)
|
205
|
+
|
206
|
+
# Before curb 0.9.8, requests was an array of Curl::Easy
|
207
|
+
# instances. Starting with 0.9.8, it's a Hash where the
|
208
|
+
# values are Curl::Easy instances.
|
209
|
+
#
|
210
|
+
# So, requests.first will either be an_obj or [a_key, an_obj].
|
211
|
+
# We need to handle either case.
|
212
|
+
#
|
213
|
+
first = first[-1] if first.is_a?(Array)
|
214
|
+
|
215
|
+
first.respond_to?(:_nr_serial) && first._nr_serial
|
216
|
+
end
|
217
|
+
end
|
218
|
+
end
|
219
|
+
end
|
220
|
+
end
|
221
|
+
end
|