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
@@ -1,246 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
- require 'json'
5
- require 'base64'
6
- require 'set'
7
-
8
- module NewRelic
9
- module Agent
10
- #
11
- # This class contains properties related to distributed traces.
12
- # To obtain an instance, call
13
- # {DistributedTracing#create_distributed_trace_payload}
14
- #
15
- # @api public
16
- class DistributedTracePayload
17
- VERSION =[0, 1].freeze
18
- PARENT_TYPE = "App".freeze
19
- POUND = '#'.freeze
20
-
21
- # Key names for serialization
22
- VERSION_KEY = 'v'.freeze
23
- DATA_KEY = 'd'.freeze
24
- PARENT_TYPE_KEY = 'ty'.freeze
25
- PARENT_ACCOUNT_ID_KEY = 'ac'.freeze
26
- PARENT_APP_KEY = 'ap'.freeze
27
- TRUSTED_ACCOUNT_KEY = 'tk'.freeze
28
- ID_KEY = 'id'.freeze
29
- TX_KEY = 'tx'.freeze
30
- TRACE_ID_KEY = 'tr'.freeze
31
- SAMPLED_KEY = 'sa'.freeze
32
- TIMESTAMP_KEY = 'ti'.freeze
33
- PRIORITY_KEY = 'pr'.freeze
34
-
35
- # Intrinsic Keys
36
- PARENT_TYPE_INTRINSIC_KEY = "parent.type".freeze
37
- PARENT_APP_INTRINSIC_KEY = "parent.app".freeze
38
- PARENT_ACCOUNT_ID_INTRINSIC_KEY = "parent.account".freeze
39
- PARENT_TRANSPORT_TYPE_INTRINSIC_KEY = "parent.transportType".freeze
40
- PARENT_TRANSPORT_DURATION_INTRINSIC_KEY = "parent.transportDuration".freeze
41
- GUID_INTRINSIC_KEY = "guid".freeze
42
- TRACE_ID_INTRINSIC_KEY = "traceId".freeze
43
- PARENT_ID_INTRINSIC_KEY = "parentId".freeze
44
- PARENT_SPAN_ID_INTRINSIC_KEY = "parentSpanId".freeze
45
- SAMPLED_INTRINSIC_KEY = "sampled".freeze
46
- COMMA = ",".freeze
47
-
48
- INTRINSIC_KEYS = [
49
- PARENT_TYPE_INTRINSIC_KEY,
50
- PARENT_APP_INTRINSIC_KEY,
51
- PARENT_ACCOUNT_ID_INTRINSIC_KEY,
52
- PARENT_TRANSPORT_TYPE_INTRINSIC_KEY,
53
- PARENT_TRANSPORT_DURATION_INTRINSIC_KEY,
54
- GUID_INTRINSIC_KEY,
55
- TRACE_ID_INTRINSIC_KEY,
56
- PARENT_ID_INTRINSIC_KEY,
57
- PARENT_SPAN_ID_INTRINSIC_KEY,
58
- SAMPLED_INTRINSIC_KEY
59
- ].freeze
60
-
61
- # Intrinsic Values
62
- PARENT_TRANSPORT_TYPE_UNKNOWN = 'Unknown'.freeze
63
-
64
- class << self
65
-
66
- def for_transaction transaction
67
- return nil unless connected?
68
-
69
- payload = new
70
- payload.version = VERSION
71
- payload.parent_type = PARENT_TYPE
72
- payload.parent_account_id = Agent.config[:account_id]
73
- payload.parent_app_id = Agent.config[:primary_application_id]
74
-
75
- assign_trusted_account_key(payload, payload.parent_account_id)
76
-
77
- payload.id = current_segment_id(transaction)
78
- payload.transaction_id = transaction.guid
79
- payload.timestamp = (Time.now.to_f * 1000).round
80
- payload.trace_id = transaction.trace_id
81
- payload.sampled = transaction.sampled?
82
- payload.priority = transaction.priority
83
-
84
- payload
85
- end
86
-
87
- def from_json serialized_payload
88
- raw_payload = JSON.parse serialized_payload
89
- return raw_payload if raw_payload.nil?
90
- payload_data = raw_payload[DATA_KEY]
91
-
92
- payload = new
93
- payload.version = raw_payload[VERSION_KEY]
94
- payload.parent_type = payload_data[PARENT_TYPE_KEY]
95
- payload.parent_account_id = payload_data[PARENT_ACCOUNT_ID_KEY]
96
- payload.parent_app_id = payload_data[PARENT_APP_KEY]
97
- payload.trusted_account_key = payload_data[TRUSTED_ACCOUNT_KEY]
98
- payload.timestamp = payload_data[TIMESTAMP_KEY]
99
- payload.id = payload_data[ID_KEY]
100
- payload.transaction_id = payload_data[TX_KEY]
101
- payload.trace_id = payload_data[TRACE_ID_KEY]
102
- payload.sampled = payload_data[SAMPLED_KEY]
103
- payload.priority = payload_data[PRIORITY_KEY]
104
-
105
- payload
106
- end
107
-
108
- def from_http_safe http_safe_payload
109
- decoded_payload = Base64.strict_decode64 http_safe_payload
110
- from_json decoded_payload
111
- end
112
-
113
- def assign_initial_intrinsics transaction, transaction_payload
114
- transaction_payload[GUID_INTRINSIC_KEY] = transaction.guid
115
- transaction_payload[TRACE_ID_INTRINSIC_KEY] = transaction.trace_id
116
- transaction_payload[SAMPLED_INTRINSIC_KEY] = transaction.sampled?
117
- end
118
-
119
- def major_version_matches?(payload)
120
- payload.version[0] == VERSION[0]
121
- end
122
-
123
- private
124
-
125
- # We use the presence of the account_id and primary_application in the
126
- # config to tell if we have connected yet.
127
- def connected?
128
- Agent.config[:account_id] && Agent.config[:primary_application_id]
129
- end
130
-
131
- def assign_trusted_account_key payload, account_id
132
- trusted_account_key = Agent.config[:trusted_account_key]
133
-
134
- if account_id != trusted_account_key
135
- payload.trusted_account_key = trusted_account_key
136
- end
137
- end
138
-
139
- def current_segment_id(transaction)
140
- if Agent.config[:'span_events.enabled'] && transaction.sampled? &&
141
- transaction.current_segment
142
- transaction.current_segment.guid
143
- end
144
- end
145
- end
146
-
147
- attr_accessor :version,
148
- :parent_type,
149
- :parent_account_id,
150
- :parent_app_id,
151
- :trusted_account_key,
152
- :id,
153
- :transaction_id,
154
- :trace_id,
155
- :sampled,
156
- :priority,
157
- :timestamp
158
-
159
- alias_method :sampled?, :sampled
160
-
161
- attr_reader :caller_transport_type
162
-
163
- def caller_transport_type=(type)
164
- @caller_transport_type = valid_transport_type_for(type)
165
- end
166
-
167
- def initialize
168
- @caller_transport_type = PARENT_TRANSPORT_TYPE_UNKNOWN
169
- end
170
-
171
- def to_json
172
- result = {
173
- VERSION_KEY => version
174
- }
175
-
176
- result[DATA_KEY] = {
177
- PARENT_TYPE_KEY => parent_type,
178
- PARENT_ACCOUNT_ID_KEY => parent_account_id,
179
- PARENT_APP_KEY => parent_app_id,
180
- TX_KEY => transaction_id,
181
- TRACE_ID_KEY => trace_id,
182
- SAMPLED_KEY => sampled,
183
- PRIORITY_KEY => priority,
184
- TIMESTAMP_KEY => timestamp,
185
- }
186
-
187
- result[DATA_KEY][ID_KEY] = id if id
188
- result[DATA_KEY][TRUSTED_ACCOUNT_KEY] = trusted_account_key if trusted_account_key
189
-
190
- JSON.dump(result)
191
- end
192
-
193
- # Encode this payload as a string suitable for passing via an
194
- # HTTP header.
195
- #
196
- # @return [String] Payload translated to JSON and encoded for
197
- # inclusion in headers
198
- #
199
- # @api public
200
- def http_safe
201
- Base64.strict_encode64 to_json
202
- end
203
-
204
- # Represent this payload as a raw JSON string.
205
- #
206
- # @return [String] Payload translated to JSON
207
- #
208
- # @api public
209
- def text
210
- to_json
211
- end
212
-
213
- def assign_intrinsics transaction, transaction_payload
214
- transaction_payload[PARENT_TYPE_INTRINSIC_KEY] = parent_type
215
- transaction_payload[PARENT_APP_INTRINSIC_KEY] = parent_app_id
216
- transaction_payload[PARENT_ACCOUNT_ID_INTRINSIC_KEY] = parent_account_id
217
- transaction_payload[PARENT_TRANSPORT_TYPE_INTRINSIC_KEY] = caller_transport_type
218
- transaction_payload[PARENT_TRANSPORT_DURATION_INTRINSIC_KEY] = transaction.transport_duration
219
- transaction_payload[GUID_INTRINSIC_KEY] = transaction.guid
220
- transaction_payload[TRACE_ID_INTRINSIC_KEY] = trace_id
221
- transaction_payload[PARENT_ID_INTRINSIC_KEY] = transaction.parent_id if transaction.parent_id
222
- transaction_payload[PARENT_SPAN_ID_INTRINSIC_KEY] = id if id
223
- transaction_payload[SAMPLED_INTRINSIC_KEY] = transaction.sampled?
224
- end
225
-
226
- private
227
-
228
- ALLOWABLE_TRANSPORT_TYPES = Set.new(%w[
229
- Unknown
230
- HTTP
231
- HTTPS
232
- Kafka
233
- JMS
234
- IronMQ
235
- AMQP
236
- Queue
237
- Other
238
- ]).freeze
239
-
240
- def valid_transport_type_for(value)
241
- return value if ALLOWABLE_TRANSPORT_TYPES.include?(value)
242
- PARENT_TRANSPORT_TYPE_UNKNOWN
243
- end
244
- end
245
- end
246
- end
@@ -1,31 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
-
5
- module NewRelic
6
- module Agent
7
- module HTTPClients
8
-
9
- # This class provides a public interface for wrapping HTTP requests. This
10
- # may be used to create wrappers that are compatible with New Relic's
11
- # external request API.
12
- #
13
- # @api public
14
- class AbstractRequest
15
- ERROR_MESSAGE = 'Subclasses of NewRelic::Agent::HTTPClients::AbstractRequest must implement a '.freeze
16
-
17
- def []
18
- raise NotImplementedError, ERROR_MESSAGE + ':[] method'
19
- end
20
-
21
- def []=
22
- raise NotImplementedError, ERROR_MESSAGE + ':[]= method'
23
- end
24
-
25
- def host_from_header
26
- raise NotImplementedError, ERROR_MESSAGE + ':host_from_header method'
27
- end
28
- end
29
- end
30
- end
31
- end
@@ -1,42 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
-
5
- require 'new_relic/agent/instrumentation/active_record_prepend'
6
- require 'new_relic/agent/instrumentation/active_record_subscriber'
7
- require 'new_relic/agent/prepend_supportability'
8
-
9
- DependencyDetection.defer do
10
- named :active_record_4
11
-
12
- depends_on do
13
- defined?(::ActiveRecord) && defined?(::ActiveRecord::Base) &&
14
- defined?(::ActiveRecord::VERSION) &&
15
- ::ActiveRecord::VERSION::MAJOR.to_i == 4
16
- end
17
-
18
- depends_on do
19
- !NewRelic::Agent.config[:disable_activerecord_instrumentation] &&
20
- !NewRelic::Agent::Instrumentation::ActiveRecordSubscriber.subscribed?
21
- end
22
-
23
- executes do
24
- ::NewRelic::Agent.logger.info 'Installing ActiveRecord 4 instrumentation'
25
- end
26
-
27
- executes do
28
- ActiveSupport::Notifications.subscribe('sql.active_record',
29
- NewRelic::Agent::Instrumentation::ActiveRecordSubscriber.new)
30
-
31
- ActiveSupport.on_load(:active_record) do
32
- ::NewRelic::Agent::PrependSupportability.record_metrics_for(::ActiveRecord::Base, ::ActiveRecord::Relation)
33
-
34
- if NewRelic::Agent.config[:prepend_active_record_instrumentation]
35
- ::ActiveRecord::Base.prepend ::NewRelic::Agent::Instrumentation::ActiveRecordPrepend::BaseExtensions
36
- ::ActiveRecord::Relation.prepend ::NewRelic::Agent::Instrumentation::ActiveRecordPrepend::RelationExtensions
37
- else
38
- ::NewRelic::Agent::Instrumentation::ActiveRecordHelper.instrument_additional_methods
39
- end
40
- end
41
- end
42
- end
@@ -1,41 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
-
5
- require 'new_relic/agent/instrumentation/active_record_subscriber'
6
- require 'new_relic/agent/instrumentation/active_record_prepend'
7
-
8
- DependencyDetection.defer do
9
- named :active_record_5
10
-
11
- depends_on do
12
- defined?(::ActiveRecord) && defined?(::ActiveRecord::Base) &&
13
- defined?(::ActiveRecord::VERSION) &&
14
- ::ActiveRecord::VERSION::MAJOR.to_i == 5
15
- end
16
-
17
- depends_on do
18
- !NewRelic::Agent.config[:disable_activerecord_instrumentation] &&
19
- !NewRelic::Agent::Instrumentation::ActiveRecordSubscriber.subscribed?
20
- end
21
-
22
- executes do
23
- ::NewRelic::Agent.logger.info 'Installing ActiveRecord 5 instrumentation'
24
- end
25
-
26
- executes do
27
- ActiveSupport::Notifications.subscribe('sql.active_record',
28
- NewRelic::Agent::Instrumentation::ActiveRecordSubscriber.new)
29
-
30
- ActiveSupport.on_load(:active_record) do
31
- ::NewRelic::Agent::PrependSupportability.record_metrics_for(::ActiveRecord::Base, ::ActiveRecord::Relation)
32
- ::ActiveRecord::Base.prepend ::NewRelic::Agent::Instrumentation::ActiveRecordPrepend::BaseExtensions
33
- ::ActiveRecord::Relation.prepend ::NewRelic::Agent::Instrumentation::ActiveRecordPrepend::RelationExtensions
34
-
35
- if ::ActiveRecord::VERSION::MINOR.to_i == 1 &&
36
- ::ActiveRecord::VERSION::TINY.to_i >= 6
37
- ::ActiveRecord::Base.prepend ::NewRelic::Agent::Instrumentation::ActiveRecordPrepend::BaseExtensions516
38
- end
39
- end
40
- end
41
- end
@@ -1,74 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
-
5
- require 'new_relic/agent/database'
6
-
7
- module NewRelic
8
- module Instrumentation
9
- module ActsAsSolrInstrumentation
10
- module ParserMethodsInstrumentation
11
- def parse_query_with_newrelic(*args)
12
- self.class.trace_execution_scoped(["SolrClient/ActsAsSolr/query"]) do
13
- begin
14
- parse_query_without_newrelic(*args)
15
- ensure
16
- return unless txn = ::NewRelic::Agent::TransactionState.tl_get.current_transaction
17
- txn.current_segment.params[:statement] = ::NewRelic::Agent::Database.truncate_query(args.first.inspect) rescue nil
18
- end
19
- end
20
- end
21
- end
22
- end
23
- end
24
- end
25
-
26
- DependencyDetection.defer do
27
- @name = :acts_as_solr
28
-
29
- depends_on do
30
- defined?(ActsAsSolr)
31
- end
32
-
33
- depends_on do
34
- defined?(ActsAsSolr::ParserMethods)
35
- end
36
-
37
- depends_on do
38
- defined?(ActsAsSolr::ClassMethods)
39
- end
40
-
41
- depends_on do
42
- defined?(ActsAsSolr::CommonMethods)
43
- end
44
-
45
- executes do
46
- ::NewRelic::Agent.logger.info 'Installing ActsAsSolr instrumentation'
47
- end
48
-
49
- executes do
50
- ActsAsSolr::ParserMethods.module_eval do
51
- include NewRelic::Instrumentation::ActsAsSolrInstrumentation::ParserMethodsInstrumentation
52
- alias :parse_query_without_newrelic :parse_query
53
- alias :parse_query :parse_query_with_newrelic
54
- end
55
- end
56
-
57
- executes do
58
- ActsAsSolr::ClassMethods.module_eval do
59
- %w[find_by_solr find_id_by_solr multi_solr_search count_by_solr].each do |method|
60
- add_method_tracer method, 'SolrClient/ActsAsSolr/query'
61
- end
62
- add_method_tracer :rebuild_solr_index, 'SolrClient/ActsAsSolr/index'
63
- end
64
- end
65
-
66
- executes do
67
- ActsAsSolr::CommonMethods.module_eval do
68
- add_method_tracer :solr_add, 'SolrClient/ActsAsSolr/add'
69
- add_method_tracer :solr_delete, 'SolrClient/ActsAsSolr/delete'
70
- add_method_tracer :solr_commit, 'SolrClient/ActsAsSolr/commit'
71
- add_method_tracer :solr_optimize, 'SolrClient/ActsAsSolr/optimize'
72
- end
73
- end
74
- end
@@ -1,25 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
-
5
- DependencyDetection.defer do
6
- @name = :authlogic
7
-
8
- depends_on do
9
- defined?(Authlogic) &&
10
- defined?(Authlogic::Session) &&
11
- defined?(Authlogic::Session::Base)
12
- end
13
-
14
- executes do
15
- ::NewRelic::Agent.logger.info 'Installing Authlogic instrumentation'
16
- end
17
-
18
- executes do
19
- Authlogic::Session::Base.class_eval do
20
- class << self
21
- add_method_tracer :find, 'Custom/Authlogic/find'
22
- end
23
- end
24
- end
25
- end
@@ -1,202 +0,0 @@
1
- # encoding: utf-8
2
- # This file is distributed under New Relic's license terms.
3
- # See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.
4
-
5
- DependencyDetection.defer do
6
- named :data_mapper
7
-
8
- depends_on do
9
- defined?(::DataMapper) &&
10
- defined?(::DataMapper::Model) &&
11
- defined?(::DataMapper::Resource) &&
12
- defined?(::DataMapper::Collection)
13
- end
14
-
15
- executes do
16
- ::NewRelic::Agent.logger.info 'Installing DataMapper instrumentation'
17
- require 'new_relic/agent/datastores/metric_helper'
18
- end
19
-
20
- executes do
21
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :get
22
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :first
23
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :last
24
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :all
25
-
26
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :create
27
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :create!
28
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :update
29
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :update!
30
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :destroy
31
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :destroy!
32
-
33
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :aggregate
34
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :find
35
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Model, :find_by_sql
36
- end
37
-
38
- executes do
39
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Resource, :update
40
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Resource, :update!
41
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Resource, :save
42
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Resource, :save!
43
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Resource, :destroy
44
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Resource, :destroy!
45
- end
46
-
47
- executes do
48
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :get
49
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :first
50
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :last
51
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :all
52
-
53
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :lazy_load
54
-
55
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :create
56
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :create!
57
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :update
58
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :update!
59
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :destroy
60
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :destroy!
61
-
62
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Collection, :aggregate
63
- end
64
-
65
- executes do
66
- # Catch direct SQL calls that bypass CRUD
67
- if defined?(::DataMapper::Adapters::DataObjectsAdapter)
68
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Adapters::DataObjectsAdapter, :select, true
69
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Adapters::DataObjectsAdapter, :execute, true
70
- end
71
- end
72
-
73
- executes do
74
- # DM::Validations overrides Model#create, so we patch it here as well
75
- if defined?(::DataMapper::Validations::ClassMethods)
76
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Validations::ClassMethods, :create
77
- end
78
- end
79
-
80
- executes do
81
- # DM::Transaction calls commit() twice, so potentially shows up twice.
82
- if defined?(::DataMapper::Transaction)
83
- NewRelic::Agent::DataMapperTracing.add_tracer ::DataMapper::Transaction, :commit, true
84
- end
85
- end
86
-
87
- executes do
88
- if defined?(::DataObjects::Connection)
89
- ::DataObjects::Connection.class_eval do
90
- include ::NewRelic::Agent::Instrumentation::DataMapperInstrumentation
91
- end
92
- end
93
- end
94
- end
95
-
96
- module NewRelic
97
- module Agent
98
- module DataMapperTracing
99
- def self.add_tracer(clazz, method_name, operation_only = false)
100
- clazz.class_eval do
101
- if method_defined?(method_name) || private_method_defined?(method_name)
102
- define_method("#{method_name}_with_newrelic",
103
- NewRelic::Agent::DataMapperTracing.method_body(clazz, method_name, operation_only))
104
-
105
- alias_method "#{method_name}_without_newrelic", method_name
106
- alias_method method_name, "#{method_name}_with_newrelic"
107
- end
108
- end
109
- end
110
-
111
- DATA_MAPPER = "DataMapper".freeze
112
- PASSWORD_REGEX = /&password=.*?(&|$)/
113
- AMPERSAND = '&'.freeze
114
- PASSWORD_PARAM = '&password='.freeze
115
-
116
- def self.method_body(clazz, method_name, operation_only)
117
- use_model_name = NewRelic::Helper.instance_methods_include?(clazz, :model)
118
- metric_operation = method_name.to_s.gsub(/[!?]/, "")
119
-
120
- Proc.new do |*args, &blk|
121
- begin
122
- if operation_only
123
- # Used by direct SQL, like ::DataMapper::Adapters::DataObjectsAdapter#select
124
- name = nil
125
- elsif use_model_name
126
- # Used by ::DataMapper::Collection to get contained model name
127
- name = self.model.name
128
- elsif self.is_a?(Class)
129
- # Used by class-style access, like Model.first()
130
- name = self.name
131
- else
132
- # Used by instance-style access, like model.update(attr: "new")
133
- name = self.class.name
134
- end
135
-
136
- segment = NewRelic::Agent::Tracer.start_datastore_segment(
137
- product: DATA_MAPPER,
138
- operation: metric_operation,
139
- collection: name
140
- )
141
-
142
- begin
143
- self.send("#{method_name}_without_newrelic", *args, &blk)
144
- rescue ::DataObjects::ConnectionError => e
145
- raise
146
- rescue ::DataObjects::SQLError => e
147
- e.uri.gsub!(PASSWORD_REGEX, AMPERSAND) if e.uri.include?(PASSWORD_PARAM)
148
-
149
- strategy = NewRelic::Agent::Database.record_sql_method(:slow_sql)
150
- case strategy
151
- when :obfuscated
152
- adapter_name = if self.respond_to?(:options)
153
- self.options[:adapter]
154
- else
155
- if self.repository.adapter.respond_to?(:options)
156
- self.repository.adapter.options[:adapter]
157
- else
158
- # DataMapper < 0.10.0
159
- self.repository.adapter.uri.scheme
160
- end
161
- end
162
- statement = NewRelic::Agent::Database::Statement.new(e.query, :adapter => adapter_name)
163
- obfuscated_sql = NewRelic::Agent::Database.obfuscate_sql(statement)
164
- e.instance_variable_set(:@query, obfuscated_sql)
165
- when :off
166
- e.instance_variable_set(:@query, nil)
167
- end
168
-
169
- raise
170
- ensure
171
- segment.finish if segment
172
- end
173
- end
174
- end
175
- end
176
- end
177
-
178
- module Instrumentation
179
- module DataMapperInstrumentation
180
- # Unlike in AR, log is called in DM after the query actually ran,
181
- # complete with metrics. Since DO has already calculated the
182
- # duration, there's nothing more to measure, so just record and log.
183
- #
184
- # We rely on the assumption that all possible entry points have been
185
- # hooked with tracers, ensuring that notice_sql attaches this SQL to
186
- # the proper call scope.
187
- def log(msg) #THREAD_LOCAL_ACCESS
188
- state = NewRelic::Agent::TransactionState.tl_get
189
- return unless state.is_execution_traced?
190
-
191
- txn = state.current_transaction
192
-
193
- if txn && txn.current_segment.respond_to?(:notice_sql)
194
- txn.current_segment.notice_sql msg.query
195
- end
196
- ensure
197
- super
198
- end
199
- end
200
- end
201
- end
202
- end