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