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,10 @@
|
|
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/tracing'
|
6
|
-
require 'new_relic/agent/cross_app_tracing'
|
7
|
-
require 'new_relic/agent/cross_app_payload'
|
6
|
+
require 'new_relic/agent/distributed_tracing/cross_app_tracing'
|
7
|
+
require 'new_relic/agent/distributed_tracing/cross_app_payload'
|
8
8
|
|
9
9
|
module NewRelic
|
10
10
|
module Agent
|
@@ -18,41 +18,12 @@ module NewRelic
|
|
18
18
|
module External
|
19
19
|
extend self
|
20
20
|
|
21
|
-
|
22
|
-
# given library, URI, and procedure. This is used to time external calls
|
23
|
-
# made over HTTP.
|
24
|
-
#
|
25
|
-
# @param [String] library a string of the class name of the library used to
|
26
|
-
# make the external call, for example, 'Net::HTTP'.
|
27
|
-
#
|
28
|
-
# @param [String, URI] uri indicates the URI to which the
|
29
|
-
# external request is being made. The URI should begin with the protocol,
|
30
|
-
# for example, 'https://github.com'.
|
31
|
-
#
|
32
|
-
# @param [String] procedure the HTTP method being used for the external
|
33
|
-
# request as a string, for example, 'GET'.
|
34
|
-
#
|
35
|
-
# @api public
|
36
|
-
def start_segment(library: nil, uri: nil, procedure: nil)
|
37
|
-
raise ArgumentError, 'Argument `library` is required' if library.nil?
|
38
|
-
raise ArgumentError, 'Argument `uri` is required' if uri.nil?
|
39
|
-
raise ArgumentError, 'Argument `procedure` is required' if procedure.nil?
|
40
|
-
|
41
|
-
::NewRelic::Agent.record_api_supportability_metric(:start_segment)
|
42
|
-
|
43
|
-
::NewRelic::Agent::Transaction.start_external_request_segment(
|
44
|
-
library: library,
|
45
|
-
uri: uri,
|
46
|
-
procedure: procedure
|
47
|
-
)
|
48
|
-
end
|
49
|
-
|
50
|
-
NON_HTTP_CAT_ID_HEADER = 'NewRelicID'.freeze
|
21
|
+
NON_HTTP_CAT_ID_HEADER = 'NewRelicID'.freeze
|
51
22
|
NON_HTTP_CAT_TXN_HEADER = 'NewRelicTransaction'.freeze
|
52
23
|
NON_HTTP_CAT_SYNTHETICS_HEADER = 'NewRelicSynthetics'.freeze
|
53
24
|
NON_HTTP_CAT_CONTENT_LENGTH = -1
|
54
25
|
|
55
|
-
# Process obfuscated +String+
|
26
|
+
# Process obfuscated +String+ identifying a calling application and transaction that is also running a
|
56
27
|
# New Relic agent and save information in current transaction for inclusion in a trace. The +String+ is
|
57
28
|
# generated by +get_request_metadata+ on the calling application.
|
58
29
|
#
|
@@ -60,13 +31,13 @@ module NewRelic
|
|
60
31
|
#
|
61
32
|
# @api public
|
62
33
|
#
|
63
|
-
def process_request_metadata
|
34
|
+
def process_request_metadata(request_metadata)
|
64
35
|
NewRelic::Agent.record_api_supportability_metric(:process_request_metadata)
|
65
36
|
return unless CrossAppTracing.cross_app_enabled?
|
66
37
|
|
67
|
-
state = NewRelic::Agent::
|
38
|
+
state = NewRelic::Agent::Tracer.state
|
68
39
|
if transaction = state.current_transaction
|
69
|
-
rmd = ::JSON.parse
|
40
|
+
rmd = ::JSON.parse(obfuscator.deobfuscate(request_metadata))
|
70
41
|
|
71
42
|
# handle/check ID
|
72
43
|
#
|
@@ -75,26 +46,26 @@ module NewRelic
|
|
75
46
|
#
|
76
47
|
if txn_info = rmd[NON_HTTP_CAT_TXN_HEADER]
|
77
48
|
payload = CrossAppPayload.new(id, transaction, txn_info)
|
78
|
-
transaction.cross_app_payload = payload
|
49
|
+
transaction.distributed_tracer.cross_app_payload = payload
|
79
50
|
|
80
|
-
CrossAppTracing.assign_intrinsic_transaction_attributes
|
51
|
+
CrossAppTracing.assign_intrinsic_transaction_attributes(state)
|
81
52
|
end
|
82
53
|
|
83
54
|
# handle synthetics
|
84
55
|
#
|
85
56
|
if synth = rmd[NON_HTTP_CAT_SYNTHETICS_HEADER]
|
86
57
|
transaction.synthetics_payload = synth
|
87
|
-
transaction.raw_synthetics_header = obfuscator.obfuscate
|
58
|
+
transaction.raw_synthetics_header = obfuscator.obfuscate(::JSON.dump(synth))
|
88
59
|
end
|
89
60
|
|
90
61
|
else
|
91
|
-
NewRelic::Agent.logger.error
|
62
|
+
NewRelic::Agent.logger.error("error processing request metadata: invalid/non-trusted ID: '#{id}'")
|
92
63
|
end
|
93
64
|
|
94
65
|
nil
|
95
66
|
end
|
96
67
|
rescue => e
|
97
|
-
NewRelic::Agent.logger.error
|
68
|
+
NewRelic::Agent.logger.error('error during process_request_metadata', e)
|
98
69
|
end
|
99
70
|
|
100
71
|
# Obtain an obfuscated +String+ suitable for delivery across public networks that carries transaction
|
@@ -109,25 +80,24 @@ module NewRelic
|
|
109
80
|
NewRelic::Agent.record_api_supportability_metric(:get_response_metadata)
|
110
81
|
return unless CrossAppTracing.cross_app_enabled?
|
111
82
|
|
112
|
-
|
113
|
-
return unless (
|
114
|
-
return unless (cross_app_payload = transaction.cross_app_payload)
|
83
|
+
return unless (txn = Tracer.current_transaction)
|
84
|
+
return unless (payload = txn.distributed_tracer.cross_app_payload)
|
115
85
|
|
116
86
|
# must freeze the name since we're responding with it
|
117
87
|
#
|
118
|
-
|
88
|
+
txn.freeze_name_and_execute_if_not_ignored do
|
119
89
|
# build response payload
|
120
90
|
#
|
121
91
|
rmd = {
|
122
|
-
NewRelicAppData:
|
92
|
+
NewRelicAppData: payload.as_json_array(NON_HTTP_CAT_CONTENT_LENGTH)
|
123
93
|
}
|
124
94
|
|
125
95
|
# obfuscate the generated response metadata JSON
|
126
96
|
#
|
127
|
-
obfuscator.obfuscate
|
97
|
+
obfuscator.obfuscate(::JSON.dump(rmd))
|
128
98
|
end
|
129
99
|
rescue => e
|
130
|
-
NewRelic::Agent.logger.error
|
100
|
+
NewRelic::Agent.logger.error("error during get_response_metadata", e)
|
131
101
|
end
|
132
102
|
|
133
103
|
private
|
@@ -135,7 +105,6 @@ module NewRelic
|
|
135
105
|
def obfuscator
|
136
106
|
CrossAppTracing.obfuscator
|
137
107
|
end
|
138
|
-
|
139
108
|
end
|
140
109
|
end
|
141
110
|
end
|
@@ -0,0 +1,30 @@
|
|
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 GuidGenerator
|
8
|
+
module_function
|
9
|
+
|
10
|
+
MAX_RAND_16 = 16**16
|
11
|
+
MAX_RAND_32 = 16**32
|
12
|
+
# This method intentionally does not use SecureRandom, because it relies
|
13
|
+
# on urandom, which raises an exception in MRI when the interpreter runs
|
14
|
+
# out of allocated file descriptors.
|
15
|
+
# The guids generated by this method may not be _secure_, but they are
|
16
|
+
# random enough for our purposes.
|
17
|
+
def generate_guid(length = 16)
|
18
|
+
guid = case length
|
19
|
+
when 16
|
20
|
+
rand(MAX_RAND_16)
|
21
|
+
when 32
|
22
|
+
rand(MAX_RAND_32)
|
23
|
+
else
|
24
|
+
rand(16**length)
|
25
|
+
end.to_s(16)
|
26
|
+
guid.length < length ? guid.rjust(length, '0') : guid
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -1,15 +1,14 @@
|
|
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
|
module NewRelic
|
6
6
|
module Agent
|
7
7
|
class Harvester
|
8
|
-
|
9
8
|
attr_accessor :starting_pid
|
10
9
|
|
11
10
|
# Inject target for after_fork call to avoid spawning thread in tests
|
12
|
-
def initialize(events, after_forker=NewRelic::Agent)
|
11
|
+
def initialize(events, after_forker = NewRelic::Agent)
|
13
12
|
# We intentionally don't set our pid as started at this point.
|
14
13
|
# Startup routines must call mark_started when they consider us set!
|
15
14
|
@starting_pid = nil
|
@@ -22,8 +21,8 @@ module NewRelic
|
|
22
21
|
|
23
22
|
def on_transaction(*_)
|
24
23
|
return unless restart_in_children_enabled? &&
|
25
|
-
|
26
|
-
|
24
|
+
needs_restart? &&
|
25
|
+
harvest_thread_enabled?
|
27
26
|
|
28
27
|
restart_harvest_thread
|
29
28
|
end
|
data/lib/new_relic/agent/heap.rb
CHANGED
@@ -1,12 +1,12 @@
|
|
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
|
module NewRelic
|
6
6
|
module Agent
|
7
7
|
# This class implements a min Heap. The first element is always the one with the
|
8
8
|
# lowest priority. It is a tree structure that is represented as an array. The
|
9
|
-
# relationship between
|
9
|
+
# relationship between nodes in the tree and indices in the array are as
|
10
10
|
# follows:
|
11
11
|
#
|
12
12
|
# parent_index = (child_index - 1) / 2
|
@@ -18,8 +18,7 @@ module NewRelic
|
|
18
18
|
#
|
19
19
|
|
20
20
|
class Heap
|
21
|
-
|
22
|
-
# @param [Array] items an optional array of items to intialize the heap
|
21
|
+
# @param [Array] items an optional array of items to initialize the heap
|
23
22
|
#
|
24
23
|
# @param [Callable] priority_fn an optional priority function used to
|
25
24
|
# to compute the priority for an item. If it's not supplied priority
|
@@ -27,7 +26,7 @@ module NewRelic
|
|
27
26
|
def initialize(items = nil, &priority_fn)
|
28
27
|
@items = []
|
29
28
|
@priority_fn = priority_fn || ->(x) { x }
|
30
|
-
items.each{ |item| push(item) } if items
|
29
|
+
items.each { |item| push(item) } if items
|
31
30
|
end
|
32
31
|
|
33
32
|
def [](index)
|
@@ -90,12 +89,12 @@ module NewRelic
|
|
90
89
|
@priority_fn.call(@items[index])
|
91
90
|
end
|
92
91
|
|
93
|
-
def parent_index_for
|
92
|
+
def parent_index_for(child_index)
|
94
93
|
(child_index - 1) / 2
|
95
94
|
end
|
96
95
|
|
97
|
-
def left_child_index_for
|
98
|
-
|
96
|
+
def left_child_index_for(parent_index)
|
97
|
+
parent_index * 2 + 1
|
99
98
|
end
|
100
99
|
|
101
100
|
def right_sibling_smaller?(lchild_index)
|
@@ -135,6 +134,5 @@ module NewRelic
|
|
135
134
|
@items[i], @items[j] = @items[j], @items[i]
|
136
135
|
end
|
137
136
|
end
|
138
|
-
|
139
137
|
end
|
140
138
|
end
|
@@ -1,6 +1,9 @@
|
|
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
|
+
|
5
|
+
require 'socket'
|
6
|
+
require 'new_relic/helper'
|
4
7
|
|
5
8
|
module NewRelic
|
6
9
|
module Agent
|
@@ -12,8 +15,26 @@ module NewRelic
|
|
12
15
|
dyno_name = "#{matching_prefix}.*" if matching_prefix
|
13
16
|
dyno_name
|
14
17
|
else
|
15
|
-
Socket.gethostname
|
18
|
+
Socket.gethostname.force_encoding(Encoding::UTF_8)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
# Pass '-f' to the external executable 'hostname' to request the fully
|
23
|
+
# qualified domain name (fqdn). For implementations of 'hostname' that
|
24
|
+
# do not support '-f' (such as the one OpenBSD ships with), fall back
|
25
|
+
# to calling 'hostname' without the '-f'. If both ways of calling
|
26
|
+
# 'hostname' fail, or in a context where 'hostname' is not even
|
27
|
+
# available (within an AWS Lambda function, for example), call the
|
28
|
+
# 'get' method which uses Socket instead of an external executable.
|
29
|
+
def self.get_fqdn
|
30
|
+
begin
|
31
|
+
NewRelic::Helper.run_command('hostname -f')
|
32
|
+
rescue NewRelic::CommandRunFailedError
|
33
|
+
NewRelic::Helper.run_command('hostname')
|
16
34
|
end
|
35
|
+
rescue NewRelic::CommandExecutableNotFoundError, NewRelic::CommandRunFailedError => e
|
36
|
+
NewRelic::Agent.logger.debug("#{e.class} - #{e.message}")
|
37
|
+
get
|
17
38
|
end
|
18
39
|
|
19
40
|
def self.heroku_dyno_name_prefix(dyno_name)
|
@@ -36,11 +57,11 @@ module NewRelic
|
|
36
57
|
::
|
37
58
|
].freeze
|
38
59
|
|
39
|
-
def self.local?
|
60
|
+
def self.local?(host_or_ip)
|
40
61
|
LOCALHOST.include?(host_or_ip)
|
41
62
|
end
|
42
63
|
|
43
|
-
def self.get_external
|
64
|
+
def self.get_external(host_or_ip)
|
44
65
|
local?(host_or_ip) ? get : host_or_ip
|
45
66
|
end
|
46
67
|
end
|
@@ -0,0 +1,81 @@
|
|
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 HTTPClients
|
8
|
+
MUST_IMPLEMENT_ERROR = "Subclasses of %s must implement a :%s method"
|
9
|
+
WHINY_NIL_ERROR = "%s cannot initialize with a nil wrapped_response object."
|
10
|
+
|
11
|
+
# This class provides a public interface for wrapping HTTP requests. This
|
12
|
+
# may be used to create wrappers that are compatible with New Relic's
|
13
|
+
# external request API.
|
14
|
+
#
|
15
|
+
# @api public
|
16
|
+
class AbstractRequest
|
17
|
+
def []
|
18
|
+
raise NotImplementedError, MUST_IMPLEMENT_ERROR % [self.class, __method__]
|
19
|
+
end
|
20
|
+
|
21
|
+
def []=
|
22
|
+
raise NotImplementedError, MUST_IMPLEMENT_ERROR % [self.class, __method__]
|
23
|
+
end
|
24
|
+
|
25
|
+
def type
|
26
|
+
raise NotImplementedError, MUST_IMPLEMENT_ERROR % [self.class, __method__]
|
27
|
+
end
|
28
|
+
|
29
|
+
def host_from_header
|
30
|
+
raise NotImplementedError, MUST_IMPLEMENT_ERROR % [self.class, __method__]
|
31
|
+
end
|
32
|
+
|
33
|
+
def host
|
34
|
+
raise NotImplementedError, MUST_IMPLEMENT_ERROR % [self.class, __method__]
|
35
|
+
end
|
36
|
+
|
37
|
+
def method
|
38
|
+
raise NotImplementedError, MUST_IMPLEMENT_ERROR % [self.class, __method__]
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
# This class implements the adaptor pattern and is used internally provide
|
43
|
+
# uniform access to the underlying HTTP Client's response object
|
44
|
+
# NOTE: response_object should be non-nil!
|
45
|
+
class AbstractResponse # :nodoc:
|
46
|
+
def initialize(wrapped_response)
|
47
|
+
if wrapped_response.nil?
|
48
|
+
raise ArgumentError, WHINY_NIL_ERROR % self.class
|
49
|
+
end
|
50
|
+
|
51
|
+
@wrapped_response = wrapped_response
|
52
|
+
end
|
53
|
+
|
54
|
+
def has_status_code?
|
55
|
+
!!status_code
|
56
|
+
end
|
57
|
+
|
58
|
+
# most HTTP client libraries report the HTTP status code as an integer, so
|
59
|
+
# we expect status_code to be set only if a non-zero value is present
|
60
|
+
def status_code
|
61
|
+
@status_code ||= get_status_code
|
62
|
+
end
|
63
|
+
|
64
|
+
private
|
65
|
+
|
66
|
+
def get_status_code_using(method_name)
|
67
|
+
return unless @wrapped_response.respond_to?(method_name)
|
68
|
+
|
69
|
+
code = @wrapped_response.send(method_name).to_i
|
70
|
+
code == 0 ? nil : code
|
71
|
+
end
|
72
|
+
|
73
|
+
# Override this method to memoize a non-zero Integer representation
|
74
|
+
# of HTTP status code from the response object
|
75
|
+
def get_status_code
|
76
|
+
get_status_code_using(:code)
|
77
|
+
end
|
78
|
+
end
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
@@ -1,19 +1,18 @@
|
|
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_relative 'abstract'
|
6
6
|
|
7
7
|
module NewRelic
|
8
8
|
module Agent
|
9
9
|
module HTTPClients
|
10
|
-
|
11
10
|
class CurbRequest
|
12
|
-
CURB = 'Curb'
|
13
|
-
LHOST = 'host'
|
14
|
-
UHOST = 'Host'
|
11
|
+
CURB = 'Curb'
|
12
|
+
LHOST = 'host'
|
13
|
+
UHOST = 'Host'
|
15
14
|
|
16
|
-
def initialize(
|
15
|
+
def initialize(curlobj)
|
17
16
|
@curlobj = curlobj
|
18
17
|
end
|
19
18
|
|
@@ -33,45 +32,46 @@ module NewRelic
|
|
33
32
|
@curlobj._nr_http_verb
|
34
33
|
end
|
35
34
|
|
36
|
-
def [](
|
37
|
-
@curlobj.headers[
|
35
|
+
def [](key)
|
36
|
+
@curlobj.headers[key]
|
38
37
|
end
|
39
38
|
|
40
|
-
def []=(
|
41
|
-
@curlobj.headers[
|
39
|
+
def []=(key, value)
|
40
|
+
@curlobj.headers[key] = value
|
42
41
|
end
|
43
42
|
|
44
43
|
def uri
|
45
|
-
@uri ||=
|
44
|
+
@uri ||= URIUtil.parse_and_normalize_url(@curlobj.url)
|
46
45
|
end
|
47
46
|
end
|
48
47
|
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
def initialize(curlobj)
|
48
|
+
class CurbResponse < AbstractResponse
|
49
|
+
def initialize(wrapped_response)
|
50
|
+
super(wrapped_response)
|
53
51
|
@headers = {}
|
54
|
-
@curlobj = curlobj
|
55
52
|
end
|
56
53
|
|
57
54
|
def [](key)
|
58
|
-
@headers[
|
55
|
+
@headers[key.downcase]
|
59
56
|
end
|
60
57
|
|
61
58
|
def to_hash
|
62
59
|
@headers.dup
|
63
60
|
end
|
64
61
|
|
65
|
-
def append_header_data(
|
66
|
-
key, value = data.split(
|
67
|
-
@headers[
|
68
|
-
@
|
69
|
-
@
|
62
|
+
def append_header_data(data)
|
63
|
+
key, value = data.split(/:\s*/, 2)
|
64
|
+
@headers[key.downcase] = value
|
65
|
+
@wrapped_response._nr_header_str ||= String.new
|
66
|
+
@wrapped_response._nr_header_str << data
|
70
67
|
end
|
71
68
|
|
72
|
-
|
69
|
+
private
|
73
70
|
|
71
|
+
def get_status_code
|
72
|
+
get_status_code_using(:response_code)
|
73
|
+
end
|
74
|
+
end
|
74
75
|
end
|
75
|
-
|
76
76
|
end
|
77
77
|
end
|
@@ -1,20 +1,20 @@
|
|
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_relative 'abstract'
|
6
6
|
|
7
7
|
module NewRelic
|
8
8
|
module Agent
|
9
9
|
module HTTPClients
|
10
|
-
class ExconHTTPResponse
|
11
|
-
def initialize(
|
12
|
-
|
10
|
+
class ExconHTTPResponse < AbstractResponse
|
11
|
+
def initialize(wrapped_response)
|
12
|
+
super(wrapped_response)
|
13
|
+
|
13
14
|
# Since HTTP headers are case-insensitive, we normalize all of them to
|
14
15
|
# upper case here, and then also in our [](key) implementation.
|
15
16
|
@normalized_headers = {}
|
16
|
-
|
17
|
-
(headers || {}).each do |key, val|
|
17
|
+
(get_attribute(:headers) || {}).each do |key, val|
|
18
18
|
@normalized_headers[key.upcase] = val
|
19
19
|
end
|
20
20
|
end
|
@@ -26,23 +26,38 @@ module NewRelic
|
|
26
26
|
def to_hash
|
27
27
|
@normalized_headers.dup
|
28
28
|
end
|
29
|
+
|
30
|
+
private
|
31
|
+
|
32
|
+
def get_attribute(name)
|
33
|
+
if @wrapped_response.respond_to?(name)
|
34
|
+
@wrapped_response.send(name)
|
35
|
+
else
|
36
|
+
@wrapped_response[name]
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def get_status_code
|
41
|
+
code = get_attribute(:status).to_i
|
42
|
+
code == 0 ? nil : code
|
43
|
+
end
|
29
44
|
end
|
30
45
|
|
31
46
|
class ExconHTTPRequest < AbstractRequest
|
32
47
|
attr_reader :method
|
33
48
|
|
34
|
-
EXCON = "Excon"
|
35
|
-
LHOST = 'host'
|
36
|
-
UHOST = 'Host'
|
37
|
-
COLON = ':'
|
49
|
+
EXCON = "Excon"
|
50
|
+
LHOST = 'host'
|
51
|
+
UHOST = 'Host'
|
52
|
+
COLON = ':'
|
38
53
|
|
39
54
|
def initialize(datum)
|
40
55
|
@datum = datum
|
41
56
|
|
42
57
|
@method = @datum[:method].to_s.upcase
|
43
58
|
@scheme = @datum[:scheme]
|
44
|
-
@port
|
45
|
-
@path
|
59
|
+
@port = @datum[:port]
|
60
|
+
@path = @datum[:path]
|
46
61
|
end
|
47
62
|
|
48
63
|
def type
|
@@ -70,9 +85,8 @@ module NewRelic
|
|
70
85
|
end
|
71
86
|
|
72
87
|
def uri
|
73
|
-
|
74
|
-
|
75
|
-
)
|
88
|
+
url = "#{@scheme}://#{host}:#{@port}#{@path}"
|
89
|
+
URIUtil.parse_and_normalize_url(url)
|
76
90
|
end
|
77
91
|
end
|
78
92
|
end
|
@@ -1,39 +1,34 @@
|
|
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_relative 'abstract'
|
6
6
|
|
7
7
|
module NewRelic
|
8
8
|
module Agent
|
9
9
|
module HTTPClients
|
10
|
-
class HTTPResponse
|
11
|
-
attr_reader :response
|
12
|
-
|
13
|
-
def initialize(response)
|
14
|
-
@response = response
|
15
|
-
end
|
16
|
-
|
10
|
+
class HTTPResponse < AbstractResponse
|
17
11
|
def [](key)
|
18
|
-
_, value =
|
12
|
+
_, value = @wrapped_response.headers.find { |k, _| key.casecmp(k) == 0 }
|
19
13
|
value unless value.nil?
|
20
14
|
end
|
21
15
|
|
22
16
|
def to_hash
|
23
|
-
|
17
|
+
@wrapped_response.headers
|
24
18
|
end
|
25
19
|
end
|
26
20
|
|
27
21
|
class HTTPRequest < AbstractRequest
|
28
|
-
HTTP_RB = 'http.rb'
|
29
|
-
HOST
|
30
|
-
COLON
|
22
|
+
HTTP_RB = 'http.rb'
|
23
|
+
HOST = 'host'
|
24
|
+
COLON = ':'
|
31
25
|
|
32
|
-
|
26
|
+
def initialize(wrapped_request)
|
27
|
+
@wrapped_request = wrapped_request
|
28
|
+
end
|
33
29
|
|
34
|
-
def
|
35
|
-
@
|
36
|
-
@uri = request.uri
|
30
|
+
def uri
|
31
|
+
@uri ||= URIUtil.parse_and_normalize_url(@wrapped_request.uri)
|
37
32
|
end
|
38
33
|
|
39
34
|
def type
|
@@ -47,19 +42,19 @@ module NewRelic
|
|
47
42
|
end
|
48
43
|
|
49
44
|
def host
|
50
|
-
host_from_header ||
|
45
|
+
host_from_header || @wrapped_request.host
|
51
46
|
end
|
52
47
|
|
53
48
|
def method
|
54
|
-
|
49
|
+
@wrapped_request.verb.upcase
|
55
50
|
end
|
56
51
|
|
57
52
|
def [](key)
|
58
|
-
|
53
|
+
@wrapped_request.headers[key]
|
59
54
|
end
|
60
55
|
|
61
56
|
def []=(key, value)
|
62
|
-
|
57
|
+
@wrapped_request.headers[key] = value
|
63
58
|
end
|
64
59
|
end
|
65
60
|
end
|