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,8 +1,6 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
# This file is distributed under New Relic's license terms.
|
3
|
-
# See https://github.com/newrelic/
|
4
|
-
|
5
|
-
require 'objspace'
|
2
|
+
# See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
|
3
|
+
# frozen_string_literal: true
|
6
4
|
|
7
5
|
# This module powers the Busy calculation for the Capacity report in
|
8
6
|
# APM (https://rpm.newrelic.com/accounts/.../applications/.../optimize/capacity_analysis).
|
@@ -14,36 +12,36 @@ require 'objspace'
|
|
14
12
|
module NewRelic
|
15
13
|
module Agent
|
16
14
|
module TransactionTimeAggregator
|
17
|
-
TransactionStats = Struct.new
|
15
|
+
TransactionStats = Struct.new(:transaction_started_at, :elapsed_transaction_time)
|
18
16
|
|
19
|
-
@lock
|
20
|
-
@harvest_cycle_started_at =
|
17
|
+
@lock = Mutex.new
|
18
|
+
@harvest_cycle_started_at = Process.clock_gettime(Process::CLOCK_REALTIME)
|
21
19
|
|
22
20
|
@stats = Hash.new do |h, k|
|
23
|
-
h[k] = TransactionStats.new
|
21
|
+
h[k] = TransactionStats.new(nil, 0.0)
|
24
22
|
end
|
25
23
|
|
26
|
-
def reset!(timestamp =
|
24
|
+
def reset!(timestamp = Process.clock_gettime(Process::CLOCK_REALTIME))
|
27
25
|
@harvest_cycle_started_at = timestamp
|
28
26
|
@stats.clear
|
29
27
|
end
|
30
28
|
|
31
|
-
def transaction_start(timestamp =
|
29
|
+
def transaction_start(timestamp = Process.clock_gettime(Process::CLOCK_REALTIME))
|
32
30
|
@lock.synchronize do
|
33
|
-
set_transaction_start_time
|
31
|
+
set_transaction_start_time(timestamp)
|
34
32
|
end
|
35
33
|
end
|
36
34
|
|
37
|
-
def transaction_stop(timestamp =
|
35
|
+
def transaction_stop(timestamp = Process.clock_gettime(Process::CLOCK_REALTIME), starting_thread_id = current_thread)
|
38
36
|
@lock.synchronize do
|
39
|
-
record_elapsed_transaction_time_until
|
40
|
-
set_transaction_start_time
|
37
|
+
record_elapsed_transaction_time_until(timestamp, starting_thread_id)
|
38
|
+
set_transaction_start_time(nil, starting_thread_id)
|
41
39
|
end
|
42
40
|
end
|
43
41
|
|
44
42
|
INSTANCE_BUSY_METRIC = 'Instance/Busy'.freeze
|
45
43
|
|
46
|
-
def harvest!(timestamp =
|
44
|
+
def harvest!(timestamp = Process.clock_gettime(Process::CLOCK_REALTIME))
|
47
45
|
active_threads = 0
|
48
46
|
result = @lock.synchronize do
|
49
47
|
# Sum up the transaction times spent in each thread
|
@@ -52,7 +50,7 @@ module NewRelic
|
|
52
50
|
end
|
53
51
|
|
54
52
|
active_threads = @stats.size
|
55
|
-
elapsed_harvest_time
|
53
|
+
elapsed_harvest_time = (timestamp - @harvest_cycle_started_at) * active_threads
|
56
54
|
@harvest_cycle_started_at = timestamp
|
57
55
|
|
58
56
|
# Clear out the stats for all threads, _except_ the live ones
|
@@ -77,9 +75,9 @@ module NewRelic
|
|
77
75
|
end
|
78
76
|
|
79
77
|
module_function :reset!,
|
80
|
-
|
81
|
-
|
82
|
-
|
78
|
+
:transaction_start,
|
79
|
+
:transaction_stop,
|
80
|
+
:harvest!
|
83
81
|
|
84
82
|
class << self
|
85
83
|
private
|
@@ -102,37 +100,54 @@ module NewRelic
|
|
102
100
|
end
|
103
101
|
|
104
102
|
def thread_is_alive?(thread_id)
|
105
|
-
thread =
|
103
|
+
thread = thread_by_id(thread_id)
|
106
104
|
thread && thread.alive?
|
107
105
|
rescue StandardError
|
108
106
|
false
|
109
107
|
end
|
110
108
|
|
109
|
+
# ObjectSpace is faster on MRI, but disabled by default on JRuby for
|
110
|
+
# performance reasons. We have two implementations of `thread_by_id`
|
111
|
+
# based on ruby implementation.
|
112
|
+
if RUBY_ENGINE == 'jruby'
|
113
|
+
def thread_by_id(thread_id)
|
114
|
+
Thread.list.detect { |t| t.object_id == thread_id }
|
115
|
+
end
|
116
|
+
else
|
117
|
+
require 'objspace'
|
118
|
+
|
119
|
+
def thread_by_id(thread_id)
|
120
|
+
ObjectSpace._id2ref(thread_id)
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
111
124
|
def set_transaction_start_time(timestamp, thread_id = current_thread)
|
112
125
|
@stats[thread_id].transaction_started_at = timestamp
|
113
126
|
end
|
114
127
|
|
115
128
|
def split_transaction_at_harvest(timestamp, thread_id = nil)
|
116
129
|
raise ArgumentError, 'thread_id required' unless thread_id
|
130
|
+
|
117
131
|
@stats[thread_id].transaction_started_at = timestamp
|
118
132
|
@stats[thread_id].elapsed_transaction_time = 0.0
|
119
133
|
end
|
120
134
|
|
121
|
-
def transaction_time_in_thread
|
122
|
-
return entry.elapsed_transaction_time unless in_transaction?
|
135
|
+
def transaction_time_in_thread(timestamp, thread_id, entry)
|
136
|
+
return entry.elapsed_transaction_time unless in_transaction?(thread_id)
|
123
137
|
|
124
138
|
# Count the portion of the transaction that's elapsed so far,...
|
125
|
-
elapsed = record_elapsed_transaction_time_until
|
139
|
+
elapsed = record_elapsed_transaction_time_until(timestamp, thread_id)
|
126
140
|
|
127
141
|
# ...then readjust the transaction start time to the next harvest
|
128
|
-
split_transaction_at_harvest
|
142
|
+
split_transaction_at_harvest(timestamp, thread_id)
|
129
143
|
|
130
144
|
elapsed
|
131
145
|
end
|
132
146
|
|
133
147
|
def log_missing_elapsed_transaction_time
|
134
|
-
|
135
|
-
|
148
|
+
transaction_name = Tracer.current_transaction &&
|
149
|
+
Tracer.current_transaction.best_name ||
|
150
|
+
"unknown"
|
136
151
|
NewRelic::Agent.logger.warn("Unable to calculate elapsed transaction time for #{transaction_name}")
|
137
152
|
end
|
138
153
|
end
|
@@ -1,6 +1,6 @@
|
|
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/utilization/vendor'
|
6
6
|
|
@@ -8,9 +8,39 @@ module NewRelic
|
|
8
8
|
module Agent
|
9
9
|
module Utilization
|
10
10
|
class AWS < Vendor
|
11
|
+
IMDS_BASE_URL = 'http://169.254.169.254/latest'.freeze
|
12
|
+
IMDS_KEYS = %w[instanceId instanceType availabilityZone].freeze
|
13
|
+
IMDS_TOKEN_TTL_SECS = '60'.freeze
|
14
|
+
TOKEN_OPEN_TIMEOUT_SECS = 1.freeze
|
15
|
+
TOKEN_READ_TIMEOUT_SECS = 1.freeze
|
16
|
+
|
17
|
+
class << self
|
18
|
+
def imds_token
|
19
|
+
uri = URI.parse("#{IMDS_BASE_URL}/api/token")
|
20
|
+
http = Net::HTTP.new(uri.hostname)
|
21
|
+
http.open_timeout = TOKEN_OPEN_TIMEOUT_SECS
|
22
|
+
http.read_timeout = TOKEN_READ_TIMEOUT_SECS
|
23
|
+
response = http.send_request('PUT',
|
24
|
+
uri.path,
|
25
|
+
'',
|
26
|
+
{'X-aws-ec2-metadata-token-ttl-seconds' => IMDS_TOKEN_TTL_SECS})
|
27
|
+
unless response.code == Vendor::SUCCESS
|
28
|
+
NewRelic::Agent.logger.debug('Failed to obtain an AWS token for use with IMDS - encountered ' \
|
29
|
+
"#{response.class} with HTTP response code #{response.code} - " \
|
30
|
+
'assuming non AWS')
|
31
|
+
return
|
32
|
+
end
|
33
|
+
|
34
|
+
response.body
|
35
|
+
rescue Net::OpenTimeout
|
36
|
+
NewRelic::Agent.logger.debug('Timed out waiting for AWS IMDS - assuming non AWS')
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
11
40
|
vendor_name "aws"
|
12
|
-
endpoint "
|
13
|
-
keys
|
41
|
+
endpoint "#{IMDS_BASE_URL}/dynamic/instance-identity/document"
|
42
|
+
keys IMDS_KEYS
|
43
|
+
headers 'X-aws-ec2-metadata-token' => -> { imds_token }
|
14
44
|
key_transforms :to_sym
|
15
45
|
end
|
16
46
|
end
|
@@ -1,6 +1,6 @@
|
|
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
|
@@ -9,9 +9,9 @@ module NewRelic
|
|
9
9
|
vendor_name "azure"
|
10
10
|
endpoint "http://169.254.169.254/metadata/instance/compute?api-version=2017-03-01"
|
11
11
|
headers "Metadata" => "true"
|
12
|
-
keys [
|
12
|
+
keys %w[vmId name vmSize location]
|
13
13
|
key_transforms :to_sym
|
14
14
|
end
|
15
15
|
end
|
16
16
|
end
|
17
|
-
end
|
17
|
+
end
|
@@ -1,6 +1,6 @@
|
|
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/utilization/vendor'
|
6
6
|
|
@@ -11,22 +11,22 @@ module NewRelic
|
|
11
11
|
vendor_name "gcp"
|
12
12
|
endpoint "http://metadata.google.internal/computeMetadata/v1/instance/?recursive=true"
|
13
13
|
headers "Metadata-Flavor" => "Google"
|
14
|
-
keys [
|
14
|
+
keys %w[id machineType name zone]
|
15
15
|
key_transforms :to_sym
|
16
16
|
|
17
17
|
MACH_TYPE = 'machineType'.freeze
|
18
18
|
ZONE = 'zone'.freeze
|
19
19
|
|
20
|
-
def prepare_response
|
21
|
-
body = JSON.parse
|
22
|
-
body[MACH_TYPE] = trim_leading
|
23
|
-
body[ZONE] = trim_leading
|
20
|
+
def prepare_response(response)
|
21
|
+
body = JSON.parse(response.body)
|
22
|
+
body[MACH_TYPE] = trim_leading(body[MACH_TYPE])
|
23
|
+
body[ZONE] = trim_leading(body[ZONE])
|
24
24
|
body
|
25
25
|
end
|
26
26
|
|
27
27
|
SLASH = '/'.freeze
|
28
28
|
|
29
|
-
def trim_leading
|
29
|
+
def trim_leading(value)
|
30
30
|
value.split(SLASH).last
|
31
31
|
end
|
32
32
|
end
|
@@ -1,6 +1,6 @@
|
|
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/utilization/vendor'
|
6
6
|
|
@@ -9,15 +9,16 @@ module NewRelic
|
|
9
9
|
module Utilization
|
10
10
|
class PCF < Vendor
|
11
11
|
vendor_name "pcf"
|
12
|
-
keys [
|
12
|
+
keys %w[CF_INSTANCE_GUID CF_INSTANCE_IP MEMORY_LIMIT]
|
13
13
|
key_transforms [:downcase, :to_sym]
|
14
14
|
|
15
15
|
def detect
|
16
16
|
begin
|
17
17
|
return false unless pcf_keys_present?
|
18
|
-
|
18
|
+
|
19
|
+
process_response(ENV)
|
19
20
|
rescue
|
20
|
-
NewRelic::Agent.logger.error
|
21
|
+
NewRelic::Agent.logger.error("Error occurred detecting: #{vendor_name}", e)
|
21
22
|
record_supportability_metric
|
22
23
|
false
|
23
24
|
end
|
@@ -1,6 +1,6 @@
|
|
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 'net/http'
|
6
6
|
|
@@ -9,25 +9,35 @@ module NewRelic
|
|
9
9
|
module Utilization
|
10
10
|
class Vendor
|
11
11
|
class << self
|
12
|
-
def vendor_name
|
12
|
+
def vendor_name(vendor_name = nil)
|
13
13
|
vendor_name ? @vendor_name = vendor_name.freeze : @vendor_name
|
14
14
|
end
|
15
15
|
|
16
|
-
def endpoint
|
16
|
+
def endpoint(endpoint = nil)
|
17
17
|
endpoint ? @endpoint = URI(endpoint) : @endpoint
|
18
18
|
end
|
19
19
|
|
20
|
-
def headers
|
21
|
-
headers ? @headers = headers.freeze :
|
20
|
+
def headers(headers = nil)
|
21
|
+
headers ? @headers = headers.freeze : processed_headers
|
22
22
|
end
|
23
23
|
|
24
|
-
def keys
|
24
|
+
def keys(keys = nil)
|
25
25
|
keys ? @keys = keys.freeze : @keys
|
26
26
|
end
|
27
27
|
|
28
|
-
def key_transforms
|
28
|
+
def key_transforms(key_transforms = nil)
|
29
29
|
key_transforms ? @key_transforms = Array(key_transforms).freeze : @key_transforms
|
30
30
|
end
|
31
|
+
|
32
|
+
def processed_headers
|
33
|
+
return unless @headers
|
34
|
+
|
35
|
+
@headers.each_with_object({}) do |(key, value), processed_hash|
|
36
|
+
# Header lambdas are expected to return string values. If nil comes back, replace it with :error
|
37
|
+
# to signify that the call failed.
|
38
|
+
processed_hash[key] = value.class.eql?(Proc) ? value.call || :error : value
|
39
|
+
end
|
40
|
+
end
|
31
41
|
end
|
32
42
|
|
33
43
|
attr_reader :metadata
|
@@ -48,12 +58,12 @@ module NewRelic
|
|
48
58
|
|
49
59
|
begin
|
50
60
|
if response.code == SUCCESS
|
51
|
-
process_response
|
61
|
+
process_response(prepare_response(response))
|
52
62
|
else
|
53
63
|
false
|
54
64
|
end
|
55
65
|
rescue => e
|
56
|
-
NewRelic::Agent.logger.error
|
66
|
+
NewRelic::Agent.logger.error("Error occurred detecting: #{vendor_name}", e)
|
57
67
|
record_supportability_metric
|
58
68
|
false
|
59
69
|
end
|
@@ -62,25 +72,28 @@ module NewRelic
|
|
62
72
|
private
|
63
73
|
|
64
74
|
def request_metadata
|
65
|
-
|
75
|
+
processed_headers = headers
|
76
|
+
raise if processed_headers.value?(:error)
|
77
|
+
|
78
|
+
Timeout.timeout(1) do
|
66
79
|
response = nil
|
67
|
-
Net::HTTP.start
|
68
|
-
req = Net::HTTP::Get.new
|
69
|
-
response = http.request
|
80
|
+
Net::HTTP.start(endpoint.host, endpoint.port) do |http|
|
81
|
+
req = Net::HTTP::Get.new(endpoint, processed_headers)
|
82
|
+
response = http.request(req)
|
70
83
|
end
|
71
84
|
response
|
72
85
|
end
|
73
86
|
rescue
|
74
|
-
NewRelic::Agent.logger.debug
|
87
|
+
NewRelic::Agent.logger.debug("#{vendor_name} environment not detected")
|
75
88
|
end
|
76
89
|
|
77
|
-
def prepare_response
|
78
|
-
JSON.parse
|
90
|
+
def prepare_response(response)
|
91
|
+
JSON.parse(response.body)
|
79
92
|
end
|
80
93
|
|
81
|
-
def process_response
|
94
|
+
def process_response(response)
|
82
95
|
keys.each do |key|
|
83
|
-
normalized = normalize
|
96
|
+
normalized = normalize(response[key])
|
84
97
|
if normalized
|
85
98
|
@metadata[transform_key(key)] = normalized
|
86
99
|
else
|
@@ -92,51 +105,53 @@ module NewRelic
|
|
92
105
|
true
|
93
106
|
end
|
94
107
|
|
95
|
-
def normalize
|
108
|
+
def normalize(value)
|
96
109
|
return if value.nil?
|
97
110
|
|
98
111
|
value = value.to_s
|
99
112
|
value = value.dup if value.frozen?
|
100
113
|
|
101
|
-
value.force_encoding
|
114
|
+
value.force_encoding(Encoding::UTF_8)
|
102
115
|
value.strip!
|
103
116
|
|
104
|
-
return unless valid_length?
|
105
|
-
return unless valid_chars?
|
117
|
+
return unless valid_length?(value)
|
118
|
+
return unless valid_chars?(value)
|
106
119
|
|
107
120
|
value
|
108
121
|
end
|
109
122
|
|
110
|
-
def valid_length?
|
123
|
+
def valid_length?(value)
|
111
124
|
if value.bytesize <= 255
|
112
125
|
true
|
113
126
|
else
|
114
|
-
NewRelic::Agent.logger.warn
|
127
|
+
NewRelic::Agent.logger.warn("Found invalid length value while detecting: #{vendor_name}")
|
115
128
|
false
|
116
129
|
end
|
117
130
|
end
|
118
131
|
|
119
132
|
VALID_CHARS = /^[0-9a-zA-Z_ .\/-]$/
|
120
133
|
|
121
|
-
def valid_chars?
|
134
|
+
def valid_chars?(value)
|
122
135
|
value.each_char do |ch|
|
123
136
|
next if ch =~ VALID_CHARS
|
137
|
+
|
124
138
|
code_point = ch[0].ord # this works in Ruby 1.8.7 - 2.1.2
|
125
139
|
next if code_point >= 0x80
|
126
140
|
|
127
|
-
NewRelic::Agent.logger.warn
|
141
|
+
NewRelic::Agent.logger.warn("Found invalid character while detecting: #{vendor_name}")
|
128
142
|
return false # it's in neither set of valid characters
|
129
143
|
end
|
130
144
|
true
|
131
145
|
end
|
132
146
|
|
133
|
-
def transform_key
|
147
|
+
def transform_key(key)
|
134
148
|
return key unless key_transforms
|
149
|
+
|
135
150
|
key_transforms.inject(key) { |memo, transform| memo.send(transform) }
|
136
151
|
end
|
137
152
|
|
138
153
|
def record_supportability_metric
|
139
|
-
NewRelic::Agent.increment_metric
|
154
|
+
NewRelic::Agent.increment_metric("Supportability/utilization/#{vendor_name}/error")
|
140
155
|
end
|
141
156
|
end
|
142
157
|
end
|
@@ -1,6 +1,6 @@
|
|
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/utilization/aws'
|
6
6
|
require 'new_relic/agent/utilization/gcp'
|
@@ -10,19 +10,27 @@ require 'new_relic/agent/utilization/pcf'
|
|
10
10
|
module NewRelic
|
11
11
|
module Agent
|
12
12
|
class UtilizationData
|
13
|
-
METADATA_VERSION =
|
13
|
+
METADATA_VERSION = 5
|
14
14
|
|
15
15
|
VENDORS = {
|
16
|
-
Utilization::AWS
|
17
|
-
Utilization::GCP
|
16
|
+
Utilization::AWS => :'utilization.detect_aws',
|
17
|
+
Utilization::GCP => :'utilization.detect_gcp',
|
18
18
|
Utilization::Azure => :'utilization.detect_azure',
|
19
|
-
Utilization::PCF
|
19
|
+
Utilization::PCF => :'utilization.detect_pcf'
|
20
20
|
}
|
21
21
|
|
22
22
|
def hostname
|
23
23
|
NewRelic::Agent::Hostname.get
|
24
24
|
end
|
25
25
|
|
26
|
+
def fqdn
|
27
|
+
NewRelic::Agent::Hostname.get_fqdn
|
28
|
+
end
|
29
|
+
|
30
|
+
def ip_addresses
|
31
|
+
::NewRelic::Agent::SystemInfo.ip_addresses
|
32
|
+
end
|
33
|
+
|
26
34
|
def container_id
|
27
35
|
::NewRelic::Agent::SystemInfo.docker_container_id
|
28
36
|
end
|
@@ -69,6 +77,9 @@ module NewRelic
|
|
69
77
|
append_docker_info(result)
|
70
78
|
append_configured_values(result)
|
71
79
|
append_boot_id(result)
|
80
|
+
append_ip_address(result)
|
81
|
+
append_full_hostname(result)
|
82
|
+
append_kubernetes_info(result)
|
72
83
|
|
73
84
|
result
|
74
85
|
end
|
@@ -76,6 +87,7 @@ module NewRelic
|
|
76
87
|
def append_vendor_info(collector_hash)
|
77
88
|
VENDORS.each_pair do |klass, config_option|
|
78
89
|
next unless Agent.config[config_option]
|
90
|
+
|
79
91
|
vendor = klass.new
|
80
92
|
|
81
93
|
if vendor.detect
|
@@ -105,6 +117,31 @@ module NewRelic
|
|
105
117
|
end
|
106
118
|
end
|
107
119
|
|
120
|
+
def append_ip_address(collector_hash)
|
121
|
+
ips = ip_addresses
|
122
|
+
collector_hash[:ip_address] = ips unless ips.empty?
|
123
|
+
end
|
124
|
+
|
125
|
+
KUBERNETES_SERVICE_HOST = 'KUBERNETES_SERVICE_HOST'.freeze
|
126
|
+
|
127
|
+
def append_kubernetes_info(collector_hash)
|
128
|
+
return unless Agent.config[:'utilization.detect_kubernetes']
|
129
|
+
|
130
|
+
if host = ENV[KUBERNETES_SERVICE_HOST]
|
131
|
+
collector_hash[:vendors] ||= {}
|
132
|
+
collector_hash[:vendors][:kubernetes] = {
|
133
|
+
kubernetes_service_host: host
|
134
|
+
}
|
135
|
+
end
|
136
|
+
end
|
137
|
+
|
138
|
+
def append_full_hostname(collector_hash)
|
139
|
+
full_hostname = fqdn
|
140
|
+
return if full_hostname.nil? || full_hostname.empty?
|
141
|
+
|
142
|
+
collector_hash[:full_hostname] = full_hostname
|
143
|
+
end
|
144
|
+
|
108
145
|
def config_hash
|
109
146
|
config_hash = {}
|
110
147
|
|
@@ -1,6 +1,6 @@
|
|
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 'thread'
|
6
6
|
require 'new_relic/agent/vm/snapshot'
|
@@ -1,6 +1,6 @@
|
|
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
|
# The GC::Profiler class available on MRI has to be reset periodically to avoid
|
6
6
|
# memory "leaking" in the underlying implementation. However, it's a major
|
@@ -16,7 +16,7 @@ module NewRelic
|
|
16
16
|
class MonotonicGCProfiler
|
17
17
|
def initialize
|
18
18
|
@total_time_s = 0
|
19
|
-
@lock
|
19
|
+
@lock = Mutex.new
|
20
20
|
end
|
21
21
|
|
22
22
|
def total_time_s
|
@@ -1,6 +1,6 @@
|
|
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 'thread'
|
6
6
|
require 'new_relic/agent/vm/snapshot'
|
@@ -23,32 +23,57 @@ module NewRelic
|
|
23
23
|
end
|
24
24
|
|
25
25
|
def gather_gc_stats(snap)
|
26
|
-
if supports?(:gc_runs)
|
27
|
-
|
28
|
-
|
26
|
+
gather_gc_runs(snap) if supports?(:gc_runs)
|
27
|
+
gather_derived_stats(snap) if GC.respond_to?(:stat)
|
28
|
+
end
|
29
29
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
30
|
+
def gather_gc_runs(snap)
|
31
|
+
snap.gc_runs = GC.count
|
32
|
+
end
|
33
|
+
|
34
|
+
def gather_derived_stats(snap)
|
35
|
+
stat = GC.stat
|
36
|
+
snap.total_allocated_object = derive_from_gc_stats(%i[total_allocated_objects total_allocated_object], stat)
|
37
|
+
snap.major_gc_count = derive_from_gc_stats(:major_gc_count, stat)
|
38
|
+
snap.minor_gc_count = derive_from_gc_stats(:minor_gc_count, stat)
|
39
|
+
snap.heap_live = derive_from_gc_stats(%i[heap_live_slots heap_live_slot heap_live_num], stat)
|
40
|
+
snap.heap_free = derive_from_gc_stats(%i[heap_free_slots heap_free_slot heap_free_num], stat)
|
41
|
+
end
|
42
|
+
|
43
|
+
def derive_from_gc_stats(keys, stat)
|
44
|
+
Array(keys).each do |key|
|
45
|
+
value = stat[key]
|
46
|
+
return value if value
|
37
47
|
end
|
48
|
+
nil
|
38
49
|
end
|
39
50
|
|
40
51
|
def gather_gc_time(snap)
|
41
|
-
|
42
|
-
|
43
|
-
|
52
|
+
return unless supports?(:gc_total_time)
|
53
|
+
|
54
|
+
snap.gc_total_time = NewRelic::Agent.instance.monotonic_gc_profiler.total_time_s
|
44
55
|
end
|
45
56
|
|
46
57
|
def gather_ruby_vm_stats(snap)
|
47
58
|
if supports?(:method_cache_invalidations)
|
48
|
-
|
49
|
-
snap.method_cache_invalidations = vm_stats[:global_method_state]
|
50
|
-
snap.constant_cache_invalidations = vm_stats[:global_constant_state]
|
59
|
+
snap.method_cache_invalidations = RubyVM.stat[:global_method_state]
|
51
60
|
end
|
61
|
+
|
62
|
+
if supports?(:constant_cache_invalidations)
|
63
|
+
snap.constant_cache_invalidations = gather_constant_cache_invalidations
|
64
|
+
end
|
65
|
+
|
66
|
+
if supports?(:constant_cache_misses)
|
67
|
+
snap.constant_cache_misses = gather_constant_cache_misses
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
def gather_constant_cache_invalidations
|
72
|
+
RubyVM.stat[RUBY_VERSION >= '3.2.0' ? :constant_cache_invalidations : :global_constant_state]
|
73
|
+
end
|
74
|
+
|
75
|
+
def gather_constant_cache_misses
|
76
|
+
RubyVM.stat[:constant_cache_misses]
|
52
77
|
end
|
53
78
|
|
54
79
|
def gather_thread_stats(snap)
|
@@ -66,9 +91,11 @@ module NewRelic
|
|
66
91
|
when :minor_gc_count
|
67
92
|
RUBY_VERSION >= '2.1.0'
|
68
93
|
when :method_cache_invalidations
|
69
|
-
RUBY_VERSION >= '2.1.0'
|
94
|
+
RUBY_VERSION >= '2.1.0' && RUBY_VERSION < '3.0.0'
|
70
95
|
when :constant_cache_invalidations
|
71
96
|
RUBY_VERSION >= '2.1.0'
|
97
|
+
when :constant_cache_misses
|
98
|
+
RUBY_VERSION >= '3.2.0'
|
72
99
|
else
|
73
100
|
false
|
74
101
|
end
|