ddtrace 0.54.2 → 1.10.1

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 (1222) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +654 -2
  3. data/LICENSE-3rdparty.csv +7 -1
  4. data/README.md +10 -1
  5. data/bin/ddtracerb +5 -5
  6. data/ext/ddtrace_profiling_loader/ddtrace_profiling_loader.c +134 -0
  7. data/ext/ddtrace_profiling_loader/extconf.rb +72 -0
  8. data/ext/ddtrace_profiling_native_extension/NativeExtensionDesign.md +79 -9
  9. data/ext/ddtrace_profiling_native_extension/clock_id.h +22 -1
  10. data/ext/ddtrace_profiling_native_extension/clock_id_from_pthread.c +33 -10
  11. data/ext/ddtrace_profiling_native_extension/clock_id_noop.c +11 -2
  12. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time_worker.c +821 -0
  13. data/ext/ddtrace_profiling_native_extension/collectors_dynamic_sampling_rate.c +142 -0
  14. data/ext/ddtrace_profiling_native_extension/collectors_dynamic_sampling_rate.h +14 -0
  15. data/ext/ddtrace_profiling_native_extension/collectors_idle_sampling_helper.c +241 -0
  16. data/ext/ddtrace_profiling_native_extension/collectors_idle_sampling_helper.h +3 -0
  17. data/ext/ddtrace_profiling_native_extension/collectors_stack.c +379 -0
  18. data/ext/ddtrace_profiling_native_extension/collectors_stack.h +20 -0
  19. data/ext/ddtrace_profiling_native_extension/collectors_thread_context.c +978 -0
  20. data/ext/ddtrace_profiling_native_extension/collectors_thread_context.h +14 -0
  21. data/ext/ddtrace_profiling_native_extension/extconf.rb +155 -115
  22. data/ext/ddtrace_profiling_native_extension/helpers.h +17 -0
  23. data/ext/ddtrace_profiling_native_extension/http_transport.c +347 -0
  24. data/ext/ddtrace_profiling_native_extension/libdatadog_helpers.h +25 -0
  25. data/ext/ddtrace_profiling_native_extension/native_extension_helpers.rb +319 -0
  26. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.c +706 -9
  27. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.h +42 -0
  28. data/ext/ddtrace_profiling_native_extension/profiling.c +231 -2
  29. data/ext/ddtrace_profiling_native_extension/ruby_helpers.c +110 -0
  30. data/ext/ddtrace_profiling_native_extension/ruby_helpers.h +89 -0
  31. data/ext/ddtrace_profiling_native_extension/setup_signal_handler.c +115 -0
  32. data/ext/ddtrace_profiling_native_extension/setup_signal_handler.h +11 -0
  33. data/ext/ddtrace_profiling_native_extension/stack_recorder.c +591 -0
  34. data/ext/ddtrace_profiling_native_extension/stack_recorder.h +14 -0
  35. data/ext/ddtrace_profiling_native_extension/time_helpers.c +17 -0
  36. data/ext/ddtrace_profiling_native_extension/time_helpers.h +10 -0
  37. data/lib/datadog/appsec/assets/blocked.html +99 -0
  38. data/lib/datadog/appsec/assets/blocked.json +1 -0
  39. data/lib/datadog/appsec/assets/blocked.text +5 -0
  40. data/lib/datadog/appsec/assets/waf_rules/README.md +7 -0
  41. data/lib/datadog/appsec/assets/waf_rules/recommended.json +6724 -0
  42. data/lib/datadog/appsec/assets/waf_rules/strict.json +1590 -0
  43. data/lib/datadog/appsec/assets.rb +36 -0
  44. data/lib/datadog/appsec/autoload.rb +11 -0
  45. data/lib/datadog/appsec/component.rb +41 -0
  46. data/lib/datadog/appsec/configuration/settings.rb +216 -0
  47. data/lib/datadog/appsec/configuration.rb +88 -0
  48. data/lib/datadog/appsec/contrib/auto_instrument.rb +25 -0
  49. data/lib/datadog/appsec/contrib/configuration/settings.rb +18 -0
  50. data/lib/datadog/appsec/contrib/integration.rb +35 -0
  51. data/lib/datadog/appsec/contrib/patcher.rb +10 -0
  52. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +20 -0
  53. data/lib/datadog/appsec/contrib/rack/ext.rb +13 -0
  54. data/lib/datadog/appsec/contrib/rack/gateway/request.rb +97 -0
  55. data/lib/datadog/appsec/contrib/rack/gateway/response.rb +30 -0
  56. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +176 -0
  57. data/lib/datadog/appsec/contrib/rack/integration.rb +47 -0
  58. data/lib/datadog/appsec/contrib/rack/patcher.rb +32 -0
  59. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +80 -0
  60. data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +63 -0
  61. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +63 -0
  62. data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +43 -0
  63. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +153 -0
  64. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +20 -0
  65. data/lib/datadog/appsec/contrib/rails/ext.rb +13 -0
  66. data/lib/datadog/appsec/contrib/rails/framework.rb +28 -0
  67. data/lib/datadog/appsec/contrib/rails/gateway/request.rb +67 -0
  68. data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +86 -0
  69. data/lib/datadog/appsec/contrib/rails/integration.rb +46 -0
  70. data/lib/datadog/appsec/contrib/rails/patcher.rb +159 -0
  71. data/lib/datadog/appsec/contrib/rails/reactive/action.rb +69 -0
  72. data/lib/datadog/appsec/contrib/rails/request.rb +34 -0
  73. data/lib/datadog/appsec/contrib/rails/request_middleware.rb +18 -0
  74. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +20 -0
  75. data/lib/datadog/appsec/contrib/sinatra/ext.rb +14 -0
  76. data/lib/datadog/appsec/contrib/sinatra/framework.rb +32 -0
  77. data/lib/datadog/appsec/contrib/sinatra/gateway/request.rb +17 -0
  78. data/lib/datadog/appsec/contrib/sinatra/gateway/route_params.rb +23 -0
  79. data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +131 -0
  80. data/lib/datadog/appsec/contrib/sinatra/integration.rb +46 -0
  81. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +159 -0
  82. data/lib/datadog/appsec/contrib/sinatra/reactive/routed.rb +64 -0
  83. data/lib/datadog/appsec/contrib/sinatra/request_middleware.rb +18 -0
  84. data/lib/datadog/appsec/event.rb +113 -0
  85. data/lib/datadog/appsec/ext.rb +9 -0
  86. data/lib/datadog/appsec/extensions.rb +146 -0
  87. data/lib/datadog/appsec/instrumentation/gateway/argument.rb +24 -0
  88. data/lib/datadog/appsec/instrumentation/gateway.rb +64 -0
  89. data/lib/datadog/appsec/instrumentation.rb +9 -0
  90. data/lib/datadog/appsec/monitor/gateway/watcher.rb +86 -0
  91. data/lib/datadog/appsec/monitor/reactive/set_user.rb +61 -0
  92. data/lib/datadog/appsec/monitor.rb +11 -0
  93. data/lib/datadog/appsec/processor.rb +243 -0
  94. data/lib/datadog/appsec/rate_limiter.rb +58 -0
  95. data/lib/datadog/appsec/reactive/address_hash.rb +22 -0
  96. data/lib/datadog/appsec/reactive/engine.rb +47 -0
  97. data/lib/datadog/appsec/reactive/operation.rb +68 -0
  98. data/lib/datadog/appsec/reactive/subscriber.rb +19 -0
  99. data/lib/datadog/appsec/response.rb +61 -0
  100. data/lib/datadog/appsec/utils/http/media_range.rb +199 -0
  101. data/lib/datadog/appsec/utils/http/media_type.rb +85 -0
  102. data/lib/datadog/appsec/utils/http.rb +9 -0
  103. data/lib/datadog/appsec/utils.rb +7 -0
  104. data/lib/datadog/appsec.rb +41 -0
  105. data/lib/datadog/ci/configuration/components.rb +8 -9
  106. data/lib/datadog/ci/configuration/settings.rb +19 -5
  107. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +4 -4
  108. data/lib/datadog/ci/contrib/cucumber/ext.rb +1 -1
  109. data/lib/datadog/ci/contrib/cucumber/formatter.rb +8 -15
  110. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +2 -3
  111. data/lib/datadog/ci/contrib/cucumber/integration.rb +5 -6
  112. data/lib/datadog/ci/contrib/cucumber/patcher.rb +3 -4
  113. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +4 -4
  114. data/lib/datadog/ci/contrib/rspec/example.rb +8 -15
  115. data/lib/datadog/ci/contrib/rspec/ext.rb +1 -1
  116. data/lib/datadog/ci/contrib/rspec/integration.rb +5 -6
  117. data/lib/datadog/ci/contrib/rspec/patcher.rb +3 -4
  118. data/lib/datadog/ci/ext/app_types.rb +1 -2
  119. data/lib/datadog/ci/ext/environment.rb +181 -127
  120. data/lib/datadog/ci/ext/settings.rb +1 -2
  121. data/lib/datadog/ci/ext/test.rb +0 -1
  122. data/lib/datadog/ci/extensions.rb +6 -7
  123. data/lib/datadog/ci/flush.rb +36 -0
  124. data/lib/datadog/ci/test.rb +15 -15
  125. data/lib/datadog/ci.rb +6 -5
  126. data/lib/datadog/core/buffer/cruby.rb +53 -0
  127. data/lib/datadog/core/buffer/random.rb +132 -0
  128. data/lib/datadog/core/buffer/thread_safe.rb +56 -0
  129. data/lib/datadog/core/chunker.rb +33 -0
  130. data/lib/datadog/core/configuration/agent_settings_resolver.rb +345 -0
  131. data/lib/datadog/core/configuration/base.rb +99 -0
  132. data/lib/datadog/core/configuration/components.rb +158 -0
  133. data/lib/datadog/core/configuration/dependency_resolver.rb +26 -0
  134. data/lib/datadog/core/configuration/ext.rb +24 -0
  135. data/lib/datadog/core/configuration/option.rb +67 -0
  136. data/lib/datadog/core/configuration/option_definition.rb +133 -0
  137. data/lib/datadog/core/configuration/option_definition_set.rb +20 -0
  138. data/lib/datadog/core/configuration/option_set.rb +8 -0
  139. data/lib/datadog/core/configuration/options.rb +116 -0
  140. data/lib/datadog/core/configuration/settings.rb +455 -0
  141. data/lib/datadog/core/configuration.rb +285 -0
  142. data/lib/datadog/core/diagnostics/environment_logger.rb +286 -0
  143. data/lib/datadog/core/diagnostics/health.rb +17 -0
  144. data/lib/datadog/core/encoding.rb +72 -0
  145. data/lib/datadog/core/environment/cgroup.rb +4 -5
  146. data/lib/datadog/core/environment/class_count.rb +0 -1
  147. data/lib/datadog/core/environment/container.rb +3 -5
  148. data/lib/datadog/core/environment/ext.rb +28 -11
  149. data/lib/datadog/core/environment/gc.rb +0 -1
  150. data/lib/datadog/core/environment/identity.rb +11 -6
  151. data/lib/datadog/core/environment/platform.rb +38 -0
  152. data/lib/datadog/core/environment/socket.rb +7 -2
  153. data/lib/datadog/core/environment/thread_count.rb +0 -1
  154. data/lib/datadog/core/environment/variable_helpers.rb +84 -12
  155. data/lib/datadog/core/environment/vm_cache.rb +17 -1
  156. data/lib/datadog/core/error.rb +99 -0
  157. data/lib/datadog/core/extensions.rb +14 -0
  158. data/lib/datadog/core/git/ext.rb +33 -0
  159. data/lib/datadog/core/header_collection.rb +41 -0
  160. data/lib/datadog/core/logger.rb +44 -0
  161. data/lib/datadog/core/logging/ext.rb +11 -0
  162. data/lib/datadog/core/metrics/client.rb +197 -0
  163. data/lib/datadog/core/metrics/ext.rb +16 -0
  164. data/lib/datadog/core/metrics/helpers.rb +23 -0
  165. data/lib/datadog/core/metrics/logging.rb +42 -0
  166. data/lib/datadog/core/metrics/metric.rb +12 -0
  167. data/lib/datadog/core/metrics/options.rb +48 -0
  168. data/lib/datadog/core/pin.rb +73 -0
  169. data/lib/datadog/core/runtime/ext.rb +28 -0
  170. data/lib/datadog/core/runtime/metrics.rb +140 -0
  171. data/lib/datadog/core/telemetry/client.rb +77 -0
  172. data/lib/datadog/core/telemetry/collector.rb +231 -0
  173. data/lib/datadog/core/telemetry/emitter.rb +46 -0
  174. data/lib/datadog/core/telemetry/event.rb +67 -0
  175. data/lib/datadog/core/telemetry/ext.rb +9 -0
  176. data/lib/datadog/core/telemetry/heartbeat.rb +35 -0
  177. data/lib/datadog/core/telemetry/http/adapters/net.rb +111 -0
  178. data/lib/datadog/core/telemetry/http/env.rb +18 -0
  179. data/lib/datadog/core/telemetry/http/ext.rb +20 -0
  180. data/lib/datadog/core/telemetry/http/response.rb +64 -0
  181. data/lib/datadog/core/telemetry/http/transport.rb +51 -0
  182. data/lib/datadog/core/telemetry/v1/app_event.rb +50 -0
  183. data/lib/datadog/core/telemetry/v1/application.rb +86 -0
  184. data/lib/datadog/core/telemetry/v1/configuration.rb +25 -0
  185. data/lib/datadog/core/telemetry/v1/dependency.rb +36 -0
  186. data/lib/datadog/core/telemetry/v1/host.rb +51 -0
  187. data/lib/datadog/core/telemetry/v1/integration.rb +58 -0
  188. data/lib/datadog/core/telemetry/v1/product.rb +28 -0
  189. data/lib/datadog/core/telemetry/v1/telemetry_request.rb +100 -0
  190. data/lib/datadog/core/utils/compression.rb +34 -0
  191. data/lib/datadog/core/utils/forking.rb +61 -0
  192. data/lib/datadog/core/utils/network.rb +140 -0
  193. data/lib/datadog/core/utils/object_set.rb +41 -0
  194. data/lib/datadog/core/utils/only_once.rb +42 -0
  195. data/lib/datadog/core/utils/safe_dup.rb +25 -0
  196. data/lib/datadog/core/utils/sequence.rb +24 -0
  197. data/lib/datadog/core/utils/string_table.rb +47 -0
  198. data/lib/datadog/core/utils/time.rb +50 -0
  199. data/lib/datadog/core/utils.rb +92 -0
  200. data/lib/datadog/core/vendor/ipaddr.rb +78 -0
  201. data/lib/datadog/core/vendor/multipart-post/multipart/post/composite_read_io.rb +118 -0
  202. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +59 -0
  203. data/lib/datadog/core/vendor/multipart-post/multipart/post/parts.rb +137 -0
  204. data/lib/datadog/core/vendor/multipart-post/multipart/post/version.rb +11 -0
  205. data/lib/datadog/core/vendor/multipart-post/multipart/post.rb +10 -0
  206. data/lib/datadog/core/vendor/multipart-post/multipart.rb +14 -0
  207. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +34 -0
  208. data/lib/datadog/core/worker.rb +22 -0
  209. data/lib/datadog/core/workers/async.rb +178 -0
  210. data/lib/datadog/core/workers/interval_loop.rb +117 -0
  211. data/lib/datadog/core/workers/polling.rb +57 -0
  212. data/lib/datadog/core/workers/queue.rb +42 -0
  213. data/lib/datadog/core/workers/runtime_metrics.rb +60 -0
  214. data/lib/datadog/core.rb +45 -0
  215. data/lib/datadog/kit/appsec/events.rb +74 -0
  216. data/lib/datadog/kit/enable_core_dumps.rb +50 -0
  217. data/lib/datadog/kit/identity.rb +70 -0
  218. data/lib/datadog/kit.rb +9 -0
  219. data/lib/datadog/opentelemetry/api/context.rb +186 -0
  220. data/lib/datadog/opentelemetry/api/trace/span.rb +14 -0
  221. data/lib/datadog/opentelemetry/sdk/configurator.rb +37 -0
  222. data/lib/datadog/opentelemetry/sdk/id_generator.rb +26 -0
  223. data/lib/datadog/opentelemetry/sdk/propagator.rb +90 -0
  224. data/lib/datadog/opentelemetry/sdk/span_processor.rb +91 -0
  225. data/lib/datadog/opentelemetry.rb +47 -0
  226. data/lib/datadog/opentracer/binary_propagator.rb +24 -0
  227. data/lib/datadog/opentracer/carrier.rb +7 -0
  228. data/lib/datadog/opentracer/distributed_headers.rb +54 -0
  229. data/lib/datadog/opentracer/global_tracer.rb +15 -0
  230. data/lib/datadog/opentracer/propagator.rb +24 -0
  231. data/lib/datadog/opentracer/rack_propagator.rb +71 -0
  232. data/lib/datadog/opentracer/scope.rb +16 -0
  233. data/lib/datadog/opentracer/scope_manager.rb +7 -0
  234. data/lib/datadog/opentracer/span.rb +99 -0
  235. data/lib/datadog/opentracer/span_context.rb +17 -0
  236. data/lib/datadog/opentracer/span_context_factory.rb +25 -0
  237. data/lib/datadog/opentracer/text_map_propagator.rb +86 -0
  238. data/lib/datadog/opentracer/thread_local_scope.rb +32 -0
  239. data/lib/datadog/opentracer/thread_local_scope_manager.rb +64 -0
  240. data/lib/datadog/opentracer/tracer.rb +212 -0
  241. data/lib/datadog/opentracer.rb +22 -0
  242. data/lib/datadog/profiling/backtrace_location.rb +32 -0
  243. data/lib/datadog/profiling/buffer.rb +41 -0
  244. data/lib/datadog/profiling/collectors/code_provenance.rb +113 -0
  245. data/lib/datadog/profiling/collectors/cpu_and_wall_time_worker.rb +96 -0
  246. data/lib/datadog/profiling/collectors/dynamic_sampling_rate.rb +12 -0
  247. data/lib/datadog/profiling/collectors/idle_sampling_helper.rb +66 -0
  248. data/lib/datadog/profiling/collectors/old_stack.rb +301 -0
  249. data/lib/datadog/profiling/collectors/stack.rb +11 -0
  250. data/lib/datadog/profiling/collectors/thread_context.rb +46 -0
  251. data/lib/datadog/profiling/component.rb +161 -0
  252. data/lib/datadog/profiling/encoding/profile.rb +41 -0
  253. data/lib/datadog/profiling/event.rb +13 -0
  254. data/lib/datadog/profiling/events/stack.rb +80 -0
  255. data/lib/datadog/profiling/exporter.rb +83 -0
  256. data/lib/datadog/profiling/ext/forking.rb +96 -0
  257. data/lib/datadog/profiling/ext.rb +43 -0
  258. data/lib/datadog/profiling/flush.rb +36 -0
  259. data/lib/datadog/profiling/http_transport.rb +130 -0
  260. data/lib/datadog/profiling/load_native_extension.rb +20 -0
  261. data/lib/datadog/profiling/native_extension.rb +39 -0
  262. data/lib/datadog/profiling/old_recorder.rb +107 -0
  263. data/lib/datadog/profiling/pprof/builder.rb +125 -0
  264. data/lib/datadog/profiling/pprof/converter.rb +102 -0
  265. data/lib/datadog/profiling/pprof/message_set.rb +14 -0
  266. data/lib/datadog/profiling/pprof/payload.rb +18 -0
  267. data/lib/datadog/profiling/pprof/pprof_pb.rb +81 -0
  268. data/lib/datadog/profiling/pprof/stack_sample.rb +139 -0
  269. data/lib/datadog/profiling/pprof/string_table.rb +10 -0
  270. data/lib/datadog/profiling/pprof/template.rb +118 -0
  271. data/lib/datadog/profiling/preload.rb +3 -0
  272. data/lib/datadog/profiling/profiler.rb +39 -0
  273. data/lib/datadog/profiling/scheduler.rb +128 -0
  274. data/lib/datadog/profiling/stack_recorder.rb +74 -0
  275. data/lib/datadog/profiling/tag_builder.rb +51 -0
  276. data/lib/datadog/profiling/tasks/exec.rb +48 -0
  277. data/lib/datadog/profiling/tasks/help.rb +16 -0
  278. data/lib/datadog/profiling/tasks/setup.rb +84 -0
  279. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +43 -0
  280. data/lib/datadog/profiling/trace_identifiers/helper.rb +45 -0
  281. data/lib/datadog/profiling.rb +210 -0
  282. data/lib/datadog/tracing/analytics.rb +23 -0
  283. data/lib/datadog/tracing/buffer.rb +128 -0
  284. data/lib/datadog/tracing/client_ip.rb +61 -0
  285. data/lib/datadog/tracing/component.rb +176 -0
  286. data/lib/datadog/tracing/configuration/ext.rb +94 -0
  287. data/lib/datadog/tracing/configuration/settings.rb +451 -0
  288. data/lib/datadog/tracing/context.rb +66 -0
  289. data/lib/datadog/tracing/context_provider.rb +80 -0
  290. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +33 -0
  291. data/lib/datadog/tracing/contrib/action_cable/event.rb +69 -0
  292. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +56 -0
  293. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +61 -0
  294. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +57 -0
  295. data/lib/datadog/tracing/contrib/action_cable/events.rb +35 -0
  296. data/lib/datadog/tracing/contrib/action_cable/ext.rb +30 -0
  297. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +88 -0
  298. data/lib/datadog/tracing/contrib/action_cable/integration.rb +48 -0
  299. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +29 -0
  300. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +34 -0
  301. data/lib/datadog/tracing/contrib/action_mailer/event.rb +50 -0
  302. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +58 -0
  303. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +45 -0
  304. data/lib/datadog/tracing/contrib/action_mailer/events.rb +32 -0
  305. data/lib/datadog/tracing/contrib/action_mailer/ext.rb +31 -0
  306. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +48 -0
  307. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +27 -0
  308. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +158 -0
  309. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +27 -0
  310. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +34 -0
  311. data/lib/datadog/tracing/contrib/action_pack/ext.rb +20 -0
  312. data/lib/datadog/tracing/contrib/action_pack/integration.rb +48 -0
  313. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +25 -0
  314. data/lib/datadog/tracing/contrib/action_pack/utils.rb +38 -0
  315. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +34 -0
  316. data/lib/datadog/tracing/contrib/action_view/event.rb +33 -0
  317. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +52 -0
  318. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +55 -0
  319. data/lib/datadog/tracing/contrib/action_view/events.rb +32 -0
  320. data/lib/datadog/tracing/contrib/action_view/ext.rb +22 -0
  321. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +76 -0
  322. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +89 -0
  323. data/lib/datadog/tracing/contrib/action_view/integration.rb +55 -0
  324. data/lib/datadog/tracing/contrib/action_view/patcher.rb +45 -0
  325. data/lib/datadog/tracing/contrib/action_view/utils.rb +34 -0
  326. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +35 -0
  327. data/lib/datadog/tracing/contrib/active_job/event.rb +56 -0
  328. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +48 -0
  329. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +47 -0
  330. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +47 -0
  331. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +49 -0
  332. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +47 -0
  333. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +48 -0
  334. data/lib/datadog/tracing/contrib/active_job/events.rb +40 -0
  335. data/lib/datadog/tracing/contrib/active_job/ext.rb +37 -0
  336. data/lib/datadog/tracing/contrib/active_job/integration.rb +48 -0
  337. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +22 -0
  338. data/lib/datadog/tracing/contrib/active_job/patcher.rb +34 -0
  339. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +31 -0
  340. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +66 -0
  341. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +43 -0
  342. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +45 -0
  343. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +32 -0
  344. data/lib/datadog/tracing/contrib/active_model_serializers/ext.rb +22 -0
  345. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +43 -0
  346. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +30 -0
  347. data/lib/datadog/tracing/contrib/active_record/configuration/makara_resolver.rb +34 -0
  348. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +136 -0
  349. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +37 -0
  350. data/lib/datadog/tracing/contrib/active_record/event.rb +28 -0
  351. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +56 -0
  352. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +76 -0
  353. data/lib/datadog/tracing/contrib/active_record/events.rb +32 -0
  354. data/lib/datadog/tracing/contrib/active_record/ext.rb +27 -0
  355. data/lib/datadog/tracing/contrib/active_record/integration.rb +54 -0
  356. data/lib/datadog/tracing/contrib/active_record/patcher.rb +25 -0
  357. data/lib/datadog/tracing/contrib/active_record/utils.rb +126 -0
  358. data/lib/datadog/tracing/contrib/active_record/vendor/connection_specification.rb +305 -0
  359. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +278 -0
  360. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +71 -0
  361. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +45 -0
  362. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +33 -0
  363. data/lib/datadog/tracing/contrib/active_support/ext.rb +29 -0
  364. data/lib/datadog/tracing/contrib/active_support/integration.rb +49 -0
  365. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +69 -0
  366. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +69 -0
  367. data/lib/datadog/tracing/contrib/active_support/notifications/subscription.rb +162 -0
  368. data/lib/datadog/tracing/contrib/active_support/patcher.rb +25 -0
  369. data/lib/datadog/tracing/contrib/analytics.rb +27 -0
  370. data/lib/datadog/tracing/contrib/auto_instrument.rb +51 -0
  371. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +36 -0
  372. data/lib/datadog/tracing/contrib/aws/ext.rb +26 -0
  373. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +94 -0
  374. data/lib/datadog/tracing/contrib/aws/integration.rb +45 -0
  375. data/lib/datadog/tracing/contrib/aws/parsed_context.rb +58 -0
  376. data/lib/datadog/tracing/contrib/aws/patcher.rb +55 -0
  377. data/lib/datadog/tracing/contrib/aws/services.rb +119 -0
  378. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +21 -0
  379. data/lib/datadog/tracing/contrib/concurrent_ruby/context_composite_executor_service.rb +51 -0
  380. data/lib/datadog/tracing/contrib/concurrent_ruby/ext.rb +14 -0
  381. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +25 -0
  382. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +41 -0
  383. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +30 -0
  384. data/lib/datadog/tracing/contrib/configurable.rb +100 -0
  385. data/lib/datadog/tracing/contrib/configuration/resolver.rb +83 -0
  386. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +41 -0
  387. data/lib/datadog/tracing/contrib/configuration/settings.rb +39 -0
  388. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +36 -0
  389. data/lib/datadog/tracing/contrib/dalli/ext.rb +24 -0
  390. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +61 -0
  391. data/lib/datadog/tracing/contrib/dalli/integration.rb +50 -0
  392. data/lib/datadog/tracing/contrib/dalli/patcher.rb +26 -0
  393. data/lib/datadog/tracing/contrib/dalli/quantize.rb +24 -0
  394. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +36 -0
  395. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +26 -0
  396. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +41 -0
  397. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +35 -0
  398. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +106 -0
  399. data/lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb +32 -0
  400. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +38 -0
  401. data/lib/datadog/tracing/contrib/elasticsearch/ext.rb +27 -0
  402. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +48 -0
  403. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +152 -0
  404. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +85 -0
  405. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +40 -0
  406. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +174 -0
  407. data/lib/datadog/tracing/contrib/ethon/ext.rb +23 -0
  408. data/lib/datadog/tracing/contrib/ethon/integration.rb +46 -0
  409. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +95 -0
  410. data/lib/datadog/tracing/contrib/ethon/patcher.rb +28 -0
  411. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +40 -0
  412. data/lib/datadog/tracing/contrib/excon/ext.rb +20 -0
  413. data/lib/datadog/tracing/contrib/excon/integration.rb +46 -0
  414. data/lib/datadog/tracing/contrib/excon/middleware.rb +169 -0
  415. data/lib/datadog/tracing/contrib/excon/patcher.rb +29 -0
  416. data/lib/datadog/tracing/contrib/ext.rb +30 -0
  417. data/lib/datadog/tracing/contrib/extensions.rb +197 -0
  418. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +44 -0
  419. data/lib/datadog/tracing/contrib/faraday/connection.rb +20 -0
  420. data/lib/datadog/tracing/contrib/faraday/ext.rb +20 -0
  421. data/lib/datadog/tracing/contrib/faraday/integration.rb +46 -0
  422. data/lib/datadog/tracing/contrib/faraday/middleware.rb +91 -0
  423. data/lib/datadog/tracing/contrib/faraday/patcher.rb +54 -0
  424. data/lib/datadog/tracing/contrib/faraday/rack_builder.rb +20 -0
  425. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +40 -0
  426. data/lib/datadog/tracing/contrib/grape/endpoint.rb +248 -0
  427. data/lib/datadog/tracing/contrib/grape/ext.rb +26 -0
  428. data/lib/datadog/tracing/contrib/grape/instrumentation.rb +35 -0
  429. data/lib/datadog/tracing/contrib/grape/integration.rb +42 -0
  430. data/lib/datadog/tracing/contrib/grape/patcher.rb +31 -0
  431. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +34 -0
  432. data/lib/datadog/tracing/contrib/graphql/ext.rb +17 -0
  433. data/lib/datadog/tracing/contrib/graphql/integration.rb +42 -0
  434. data/lib/datadog/tracing/contrib/graphql/patcher.rb +88 -0
  435. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +41 -0
  436. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +97 -0
  437. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +88 -0
  438. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +105 -0
  439. data/lib/datadog/tracing/contrib/grpc/distributed/fetcher.rb +26 -0
  440. data/lib/datadog/tracing/contrib/grpc/distributed/propagation.rb +42 -0
  441. data/lib/datadog/tracing/contrib/grpc/ext.rb +25 -0
  442. data/lib/datadog/tracing/contrib/grpc/integration.rb +48 -0
  443. data/lib/datadog/tracing/contrib/grpc/intercept_with_datadog.rb +51 -0
  444. data/lib/datadog/tracing/contrib/grpc/patcher.rb +32 -0
  445. data/lib/datadog/tracing/contrib/hanami/action_tracer.rb +45 -0
  446. data/lib/datadog/tracing/contrib/hanami/configuration/settings.rb +20 -0
  447. data/lib/datadog/tracing/contrib/hanami/ext.rb +22 -0
  448. data/lib/datadog/tracing/contrib/hanami/integration.rb +42 -0
  449. data/lib/datadog/tracing/contrib/hanami/patcher.rb +31 -0
  450. data/lib/datadog/tracing/contrib/hanami/plugin.rb +21 -0
  451. data/lib/datadog/tracing/contrib/hanami/renderer_policy_tracing.rb +39 -0
  452. data/lib/datadog/tracing/contrib/hanami/router_tracing.rb +42 -0
  453. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +41 -0
  454. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +45 -0
  455. data/lib/datadog/tracing/contrib/http/distributed/fetcher.rb +38 -0
  456. data/lib/datadog/tracing/contrib/http/distributed/propagation.rb +37 -0
  457. data/lib/datadog/tracing/contrib/http/ext.rb +21 -0
  458. data/lib/datadog/tracing/contrib/http/instrumentation.rb +135 -0
  459. data/lib/datadog/tracing/contrib/http/integration.rb +47 -0
  460. data/lib/datadog/tracing/contrib/http/patcher.rb +28 -0
  461. data/lib/datadog/tracing/contrib/http_annotation_helper.rb +15 -0
  462. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +45 -0
  463. data/lib/datadog/tracing/contrib/httpclient/ext.rb +21 -0
  464. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +115 -0
  465. data/lib/datadog/tracing/contrib/httpclient/integration.rb +46 -0
  466. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +40 -0
  467. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +45 -0
  468. data/lib/datadog/tracing/contrib/httprb/ext.rb +21 -0
  469. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +126 -0
  470. data/lib/datadog/tracing/contrib/httprb/integration.rb +46 -0
  471. data/lib/datadog/tracing/contrib/httprb/patcher.rb +40 -0
  472. data/lib/datadog/tracing/contrib/integration.rb +76 -0
  473. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +33 -0
  474. data/lib/datadog/tracing/contrib/kafka/consumer_event.rb +17 -0
  475. data/lib/datadog/tracing/contrib/kafka/consumer_group_event.rb +16 -0
  476. data/lib/datadog/tracing/contrib/kafka/event.rb +51 -0
  477. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +40 -0
  478. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +47 -0
  479. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +45 -0
  480. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +45 -0
  481. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +35 -0
  482. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +35 -0
  483. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +35 -0
  484. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +39 -0
  485. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +42 -0
  486. data/lib/datadog/tracing/contrib/kafka/events.rb +46 -0
  487. data/lib/datadog/tracing/contrib/kafka/ext.rb +51 -0
  488. data/lib/datadog/tracing/contrib/kafka/integration.rb +42 -0
  489. data/lib/datadog/tracing/contrib/kafka/patcher.rb +27 -0
  490. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +21 -0
  491. data/lib/datadog/tracing/contrib/lograge/ext.rb +13 -0
  492. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +44 -0
  493. data/lib/datadog/tracing/contrib/lograge/integration.rb +48 -0
  494. data/lib/datadog/tracing/contrib/lograge/patcher.rb +27 -0
  495. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +40 -0
  496. data/lib/datadog/tracing/contrib/mongodb/ext.rb +33 -0
  497. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +45 -0
  498. data/lib/datadog/tracing/contrib/mongodb/integration.rb +46 -0
  499. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +47 -0
  500. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +32 -0
  501. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +125 -0
  502. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +48 -0
  503. data/lib/datadog/tracing/contrib/mysql2/ext.rb +22 -0
  504. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +75 -0
  505. data/lib/datadog/tracing/contrib/mysql2/integration.rb +41 -0
  506. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +29 -0
  507. data/lib/datadog/tracing/contrib/patchable.rb +107 -0
  508. data/lib/datadog/tracing/contrib/patcher.rb +84 -0
  509. data/lib/datadog/tracing/contrib/pg/configuration/settings.rb +48 -0
  510. data/lib/datadog/tracing/contrib/pg/ext.rb +31 -0
  511. data/lib/datadog/tracing/contrib/pg/instrumentation.rb +166 -0
  512. data/lib/datadog/tracing/contrib/pg/integration.rb +41 -0
  513. data/lib/datadog/tracing/contrib/pg/patcher.rb +29 -0
  514. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +36 -0
  515. data/lib/datadog/tracing/contrib/presto/ext.rb +32 -0
  516. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +125 -0
  517. data/lib/datadog/tracing/contrib/presto/integration.rb +41 -0
  518. data/lib/datadog/tracing/contrib/presto/patcher.rb +35 -0
  519. data/lib/datadog/tracing/contrib/propagation/sql_comment/comment.rb +41 -0
  520. data/lib/datadog/tracing/contrib/propagation/sql_comment/ext.rb +31 -0
  521. data/lib/datadog/tracing/contrib/propagation/sql_comment/mode.rb +26 -0
  522. data/lib/datadog/tracing/contrib/propagation/sql_comment.rb +45 -0
  523. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +38 -0
  524. data/lib/datadog/tracing/contrib/qless/ext.rb +24 -0
  525. data/lib/datadog/tracing/contrib/qless/integration.rb +41 -0
  526. data/lib/datadog/tracing/contrib/qless/patcher.rb +34 -0
  527. data/lib/datadog/tracing/contrib/qless/qless_job.rb +75 -0
  528. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +28 -0
  529. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +47 -0
  530. data/lib/datadog/tracing/contrib/que/ext.rb +32 -0
  531. data/lib/datadog/tracing/contrib/que/integration.rb +44 -0
  532. data/lib/datadog/tracing/contrib/que/patcher.rb +26 -0
  533. data/lib/datadog/tracing/contrib/que/tracer.rb +63 -0
  534. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +33 -0
  535. data/lib/datadog/tracing/contrib/racecar/event.rb +77 -0
  536. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +36 -0
  537. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +33 -0
  538. data/lib/datadog/tracing/contrib/racecar/events/message.rb +36 -0
  539. data/lib/datadog/tracing/contrib/racecar/events.rb +34 -0
  540. data/lib/datadog/tracing/contrib/racecar/ext.rb +30 -0
  541. data/lib/datadog/tracing/contrib/racecar/integration.rb +42 -0
  542. data/lib/datadog/tracing/contrib/racecar/patcher.rb +27 -0
  543. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +49 -0
  544. data/lib/datadog/tracing/contrib/rack/ext.rb +28 -0
  545. data/lib/datadog/tracing/contrib/rack/header_collection.rb +35 -0
  546. data/lib/datadog/tracing/contrib/rack/integration.rb +48 -0
  547. data/lib/datadog/tracing/contrib/rack/middlewares.rb +347 -0
  548. data/lib/datadog/tracing/contrib/rack/patcher.rb +117 -0
  549. data/lib/datadog/tracing/contrib/rack/request_queue.rb +46 -0
  550. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +10 -0
  551. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +72 -0
  552. data/lib/datadog/tracing/contrib/rails/ext.rb +17 -0
  553. data/lib/datadog/tracing/contrib/rails/framework.rb +146 -0
  554. data/lib/datadog/tracing/contrib/rails/integration.rb +47 -0
  555. data/lib/datadog/tracing/contrib/rails/log_injection.rb +30 -0
  556. data/lib/datadog/tracing/contrib/rails/middlewares.rb +44 -0
  557. data/lib/datadog/tracing/contrib/rails/patcher.rb +118 -0
  558. data/lib/datadog/tracing/contrib/rails/railtie.rb +17 -0
  559. data/lib/datadog/tracing/contrib/rails/utils.rb +26 -0
  560. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +49 -0
  561. data/lib/datadog/tracing/contrib/rake/ext.rb +24 -0
  562. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +101 -0
  563. data/lib/datadog/tracing/contrib/rake/integration.rb +41 -0
  564. data/lib/datadog/tracing/contrib/rake/patcher.rb +31 -0
  565. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +47 -0
  566. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +41 -0
  567. data/lib/datadog/tracing/contrib/redis/ext.rb +27 -0
  568. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +86 -0
  569. data/lib/datadog/tracing/contrib/redis/integration.rb +78 -0
  570. data/lib/datadog/tracing/contrib/redis/patcher.rb +77 -0
  571. data/lib/datadog/tracing/contrib/redis/quantize.rb +80 -0
  572. data/lib/datadog/tracing/contrib/redis/tags.rb +54 -0
  573. data/lib/datadog/tracing/contrib/redis/trace_middleware.rb +70 -0
  574. data/lib/datadog/tracing/contrib/redis/vendor/resolver.rb +160 -0
  575. data/lib/datadog/tracing/contrib/registerable.rb +48 -0
  576. data/lib/datadog/tracing/contrib/registry.rb +50 -0
  577. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +35 -0
  578. data/lib/datadog/tracing/contrib/resque/ext.rb +19 -0
  579. data/lib/datadog/tracing/contrib/resque/integration.rb +46 -0
  580. data/lib/datadog/tracing/contrib/resque/patcher.rb +27 -0
  581. data/lib/datadog/tracing/contrib/resque/resque_job.rb +104 -0
  582. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +40 -0
  583. data/lib/datadog/tracing/contrib/rest_client/ext.rb +20 -0
  584. data/lib/datadog/tracing/contrib/rest_client/integration.rb +41 -0
  585. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +26 -0
  586. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +104 -0
  587. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +21 -0
  588. data/lib/datadog/tracing/contrib/semantic_logger/ext.rb +13 -0
  589. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +48 -0
  590. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +50 -0
  591. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +27 -0
  592. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +31 -0
  593. data/lib/datadog/tracing/contrib/sequel/database.rb +57 -0
  594. data/lib/datadog/tracing/contrib/sequel/dataset.rb +62 -0
  595. data/lib/datadog/tracing/contrib/sequel/ext.rb +20 -0
  596. data/lib/datadog/tracing/contrib/sequel/integration.rb +41 -0
  597. data/lib/datadog/tracing/contrib/sequel/patcher.rb +35 -0
  598. data/lib/datadog/tracing/contrib/sequel/utils.rb +85 -0
  599. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +36 -0
  600. data/lib/datadog/tracing/contrib/shoryuken/ext.rb +24 -0
  601. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +42 -0
  602. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +26 -0
  603. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +63 -0
  604. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +57 -0
  605. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +42 -0
  606. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +42 -0
  607. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +51 -0
  608. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +76 -0
  609. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +54 -0
  610. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/job_fetch.rb +34 -0
  611. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/redis_info.rb +32 -0
  612. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_poller.rb +55 -0
  613. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +102 -0
  614. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +42 -0
  615. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +41 -0
  616. data/lib/datadog/tracing/contrib/sinatra/env.rb +53 -0
  617. data/lib/datadog/tracing/contrib/sinatra/ext.rb +34 -0
  618. data/lib/datadog/tracing/contrib/sinatra/framework.rb +114 -0
  619. data/lib/datadog/tracing/contrib/sinatra/headers.rb +33 -0
  620. data/lib/datadog/tracing/contrib/sinatra/integration.rb +41 -0
  621. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +73 -0
  622. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +84 -0
  623. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +125 -0
  624. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +36 -0
  625. data/lib/datadog/tracing/contrib/sneakers/ext.rb +25 -0
  626. data/lib/datadog/tracing/contrib/sneakers/integration.rb +44 -0
  627. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +27 -0
  628. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +60 -0
  629. data/lib/datadog/tracing/contrib/status_code_matcher.rb +73 -0
  630. data/lib/datadog/tracing/contrib/stripe/configuration/settings.rb +33 -0
  631. data/lib/datadog/tracing/contrib/stripe/ext.rb +26 -0
  632. data/lib/datadog/tracing/contrib/stripe/integration.rb +43 -0
  633. data/lib/datadog/tracing/contrib/stripe/patcher.rb +28 -0
  634. data/lib/datadog/tracing/contrib/stripe/request.rb +67 -0
  635. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +33 -0
  636. data/lib/datadog/tracing/contrib/sucker_punch/exception_handler.rb +26 -0
  637. data/lib/datadog/tracing/contrib/sucker_punch/ext.rb +25 -0
  638. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +102 -0
  639. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +41 -0
  640. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +33 -0
  641. data/lib/datadog/tracing/contrib/utils/database.rb +29 -0
  642. data/lib/datadog/tracing/contrib/utils/quantization/hash.rb +109 -0
  643. data/lib/datadog/tracing/contrib/utils/quantization/http.rb +177 -0
  644. data/lib/datadog/tracing/contrib.rb +77 -0
  645. data/lib/datadog/tracing/correlation.rb +112 -0
  646. data/lib/datadog/tracing/diagnostics/ext.rb +34 -0
  647. data/lib/datadog/tracing/diagnostics/health.rb +38 -0
  648. data/lib/datadog/tracing/distributed/b3_multi.rb +72 -0
  649. data/lib/datadog/tracing/distributed/b3_single.rb +68 -0
  650. data/lib/datadog/tracing/distributed/datadog.rb +200 -0
  651. data/lib/datadog/tracing/distributed/datadog_tags_codec.rb +84 -0
  652. data/lib/datadog/tracing/distributed/fetcher.rb +21 -0
  653. data/lib/datadog/tracing/distributed/headers/ext.rb +34 -0
  654. data/lib/datadog/tracing/distributed/helpers.rb +65 -0
  655. data/lib/datadog/tracing/distributed/none.rb +18 -0
  656. data/lib/datadog/tracing/distributed/propagation.rb +126 -0
  657. data/lib/datadog/tracing/distributed/trace_context.rb +373 -0
  658. data/lib/datadog/tracing/event.rb +76 -0
  659. data/lib/datadog/tracing/flush.rb +94 -0
  660. data/lib/datadog/tracing/metadata/analytics.rb +24 -0
  661. data/lib/datadog/tracing/metadata/errors.rb +22 -0
  662. data/lib/datadog/tracing/metadata/ext.rb +182 -0
  663. data/lib/datadog/tracing/metadata/tagging.rb +129 -0
  664. data/lib/datadog/tracing/metadata.rb +18 -0
  665. data/lib/datadog/tracing/pipeline/span_filter.rb +44 -0
  666. data/lib/datadog/tracing/pipeline/span_processor.rb +37 -0
  667. data/lib/datadog/tracing/pipeline.rb +63 -0
  668. data/lib/datadog/tracing/propagation/http.rb +12 -0
  669. data/lib/datadog/tracing/runtime/metrics.rb +17 -0
  670. data/lib/datadog/tracing/sampling/all_sampler.rb +23 -0
  671. data/lib/datadog/tracing/sampling/ext.rb +56 -0
  672. data/lib/datadog/tracing/sampling/matcher.rb +66 -0
  673. data/lib/datadog/tracing/sampling/priority_sampler.rb +163 -0
  674. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +94 -0
  675. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +63 -0
  676. data/lib/datadog/tracing/sampling/rate_limiter.rb +186 -0
  677. data/lib/datadog/tracing/sampling/rate_sampler.rb +70 -0
  678. data/lib/datadog/tracing/sampling/rule.rb +74 -0
  679. data/lib/datadog/tracing/sampling/rule_sampler.rb +130 -0
  680. data/lib/datadog/tracing/sampling/sampler.rb +42 -0
  681. data/lib/datadog/tracing/sampling/span/ext.rb +25 -0
  682. data/lib/datadog/tracing/sampling/span/matcher.rb +89 -0
  683. data/lib/datadog/tracing/sampling/span/rule.rb +82 -0
  684. data/lib/datadog/tracing/sampling/span/rule_parser.rb +104 -0
  685. data/lib/datadog/tracing/sampling/span/sampler.rb +75 -0
  686. data/lib/datadog/tracing/span.rb +214 -0
  687. data/lib/datadog/tracing/span_operation.rb +518 -0
  688. data/lib/datadog/tracing/sync_writer.rb +67 -0
  689. data/lib/datadog/tracing/trace_digest.rb +144 -0
  690. data/lib/datadog/tracing/trace_operation.rb +474 -0
  691. data/lib/datadog/tracing/trace_segment.rb +217 -0
  692. data/lib/datadog/tracing/tracer.rb +531 -0
  693. data/lib/datadog/tracing/utils.rb +81 -0
  694. data/lib/datadog/tracing/workers/trace_writer.rb +193 -0
  695. data/lib/datadog/tracing/workers.rb +123 -0
  696. data/lib/datadog/tracing/writer.rb +185 -0
  697. data/lib/datadog/tracing.rb +140 -0
  698. data/lib/ddtrace/auto_instrument.rb +13 -4
  699. data/lib/ddtrace/auto_instrument_base.rb +0 -1
  700. data/lib/ddtrace/profiling/preload.rb +2 -4
  701. data/lib/ddtrace/transport/ext.rb +39 -0
  702. data/lib/ddtrace/transport/http/adapters/net.rb +4 -4
  703. data/lib/ddtrace/transport/http/adapters/registry.rb +0 -1
  704. data/lib/ddtrace/transport/http/adapters/test.rb +1 -2
  705. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +3 -4
  706. data/lib/ddtrace/transport/http/api/endpoint.rb +0 -1
  707. data/lib/ddtrace/transport/http/api/fallbacks.rb +0 -1
  708. data/lib/ddtrace/transport/http/api/instance.rb +0 -1
  709. data/lib/ddtrace/transport/http/api/map.rb +1 -2
  710. data/lib/ddtrace/transport/http/api/spec.rb +0 -1
  711. data/lib/ddtrace/transport/http/api.rb +7 -15
  712. data/lib/ddtrace/transport/http/builder.rb +6 -7
  713. data/lib/ddtrace/transport/http/client.rb +4 -4
  714. data/lib/ddtrace/transport/http/env.rb +0 -1
  715. data/lib/ddtrace/transport/http/response.rb +35 -6
  716. data/lib/ddtrace/transport/http/statistics.rb +1 -2
  717. data/lib/ddtrace/transport/http/traces.rb +6 -5
  718. data/lib/ddtrace/transport/http.rb +37 -33
  719. data/lib/ddtrace/transport/io/client.rb +5 -4
  720. data/lib/ddtrace/transport/io/response.rb +1 -2
  721. data/lib/ddtrace/transport/io/traces.rb +4 -7
  722. data/lib/ddtrace/transport/io.rb +4 -5
  723. data/lib/ddtrace/transport/parcel.rb +1 -3
  724. data/lib/ddtrace/transport/request.rb +0 -1
  725. data/lib/ddtrace/transport/response.rb +0 -1
  726. data/lib/ddtrace/transport/serializable_trace.rb +122 -0
  727. data/lib/ddtrace/transport/statistics.rb +5 -5
  728. data/lib/ddtrace/transport/trace_formatter.rb +196 -0
  729. data/lib/ddtrace/transport/traces.rb +20 -10
  730. data/lib/ddtrace/version.rb +14 -14
  731. data/lib/ddtrace.rb +9 -52
  732. metadata +703 -497
  733. data/.editorconfig +0 -22
  734. data/.gitignore +0 -67
  735. data/.yardopts +0 -5
  736. data/CONTRIBUTING.md +0 -81
  737. data/ddtrace.gemspec +0 -56
  738. data/docs/DevelopmentGuide.md +0 -259
  739. data/docs/GettingStarted.md +0 -2626
  740. data/docs/ProfilingDevelopment.md +0 -107
  741. data/lib/datadog/ci/context_flush.rb +0 -29
  742. data/lib/datadog/contrib.rb +0 -71
  743. data/lib/ddtrace/analytics.rb +0 -39
  744. data/lib/ddtrace/buffer.rb +0 -340
  745. data/lib/ddtrace/chunker.rb +0 -35
  746. data/lib/ddtrace/configuration/agent_settings_resolver.rb +0 -309
  747. data/lib/ddtrace/configuration/base.rb +0 -82
  748. data/lib/ddtrace/configuration/components.rb +0 -292
  749. data/lib/ddtrace/configuration/dependency_resolver.rb +0 -25
  750. data/lib/ddtrace/configuration/option.rb +0 -65
  751. data/lib/ddtrace/configuration/option_definition.rb +0 -122
  752. data/lib/ddtrace/configuration/option_definition_set.rb +0 -19
  753. data/lib/ddtrace/configuration/option_set.rb +0 -7
  754. data/lib/ddtrace/configuration/options.rb +0 -112
  755. data/lib/ddtrace/configuration/pin_setup.rb +0 -32
  756. data/lib/ddtrace/configuration/settings.rb +0 -413
  757. data/lib/ddtrace/configuration.rb +0 -195
  758. data/lib/ddtrace/context.rb +0 -334
  759. data/lib/ddtrace/context_flush.rb +0 -82
  760. data/lib/ddtrace/context_provider.rb +0 -62
  761. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +0 -31
  762. data/lib/ddtrace/contrib/action_cable/event.rb +0 -67
  763. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +0 -50
  764. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +0 -56
  765. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +0 -51
  766. data/lib/ddtrace/contrib/action_cable/events.rb +0 -34
  767. data/lib/ddtrace/contrib/action_cable/ext.rb +0 -27
  768. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +0 -78
  769. data/lib/ddtrace/contrib/action_cable/integration.rb +0 -46
  770. data/lib/ddtrace/contrib/action_cable/patcher.rb +0 -29
  771. data/lib/ddtrace/contrib/action_mailer/configuration/settings.rb +0 -32
  772. data/lib/ddtrace/contrib/action_mailer/event.rb +0 -50
  773. data/lib/ddtrace/contrib/action_mailer/events/deliver.rb +0 -54
  774. data/lib/ddtrace/contrib/action_mailer/events/process.rb +0 -41
  775. data/lib/ddtrace/contrib/action_mailer/events.rb +0 -31
  776. data/lib/ddtrace/contrib/action_mailer/ext.rb +0 -32
  777. data/lib/ddtrace/contrib/action_mailer/integration.rb +0 -45
  778. data/lib/ddtrace/contrib/action_mailer/patcher.rb +0 -27
  779. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +0 -157
  780. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +0 -26
  781. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +0 -33
  782. data/lib/ddtrace/contrib/action_pack/ext.rb +0 -20
  783. data/lib/ddtrace/contrib/action_pack/integration.rb +0 -46
  784. data/lib/ddtrace/contrib/action_pack/patcher.rb +0 -24
  785. data/lib/ddtrace/contrib/action_pack/utils.rb +0 -37
  786. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +0 -32
  787. data/lib/ddtrace/contrib/action_view/event.rb +0 -36
  788. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +0 -47
  789. data/lib/ddtrace/contrib/action_view/events/render_template.rb +0 -50
  790. data/lib/ddtrace/contrib/action_view/events.rb +0 -31
  791. data/lib/ddtrace/contrib/action_view/ext.rb +0 -21
  792. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +0 -75
  793. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +0 -168
  794. data/lib/ddtrace/contrib/action_view/integration.rb +0 -53
  795. data/lib/ddtrace/contrib/action_view/patcher.rb +0 -48
  796. data/lib/ddtrace/contrib/action_view/utils.rb +0 -33
  797. data/lib/ddtrace/contrib/active_job/configuration/settings.rb +0 -33
  798. data/lib/ddtrace/contrib/active_job/event.rb +0 -54
  799. data/lib/ddtrace/contrib/active_job/events/discard.rb +0 -46
  800. data/lib/ddtrace/contrib/active_job/events/enqueue.rb +0 -45
  801. data/lib/ddtrace/contrib/active_job/events/enqueue_at.rb +0 -45
  802. data/lib/ddtrace/contrib/active_job/events/enqueue_retry.rb +0 -47
  803. data/lib/ddtrace/contrib/active_job/events/perform.rb +0 -45
  804. data/lib/ddtrace/contrib/active_job/events/retry_stopped.rb +0 -46
  805. data/lib/ddtrace/contrib/active_job/events.rb +0 -39
  806. data/lib/ddtrace/contrib/active_job/ext.rb +0 -32
  807. data/lib/ddtrace/contrib/active_job/integration.rb +0 -46
  808. data/lib/ddtrace/contrib/active_job/log_injection.rb +0 -21
  809. data/lib/ddtrace/contrib/active_job/patcher.rb +0 -33
  810. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +0 -31
  811. data/lib/ddtrace/contrib/active_model_serializers/event.rb +0 -69
  812. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +0 -33
  813. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +0 -36
  814. data/lib/ddtrace/contrib/active_model_serializers/events.rb +0 -31
  815. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +0 -21
  816. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +0 -41
  817. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +0 -30
  818. data/lib/ddtrace/contrib/active_record/configuration/makara_resolver.rb +0 -31
  819. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +0 -135
  820. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +0 -36
  821. data/lib/ddtrace/contrib/active_record/event.rb +0 -31
  822. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +0 -61
  823. data/lib/ddtrace/contrib/active_record/events/sql.rb +0 -69
  824. data/lib/ddtrace/contrib/active_record/events.rb +0 -31
  825. data/lib/ddtrace/contrib/active_record/ext.rb +0 -25
  826. data/lib/ddtrace/contrib/active_record/integration.rb +0 -54
  827. data/lib/ddtrace/contrib/active_record/patcher.rb +0 -24
  828. data/lib/ddtrace/contrib/active_record/utils.rb +0 -124
  829. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +0 -259
  830. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +0 -70
  831. data/lib/ddtrace/contrib/active_support/cache/redis.rb +0 -44
  832. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +0 -31
  833. data/lib/ddtrace/contrib/active_support/ext.rb +0 -28
  834. data/lib/ddtrace/contrib/active_support/integration.rb +0 -47
  835. data/lib/ddtrace/contrib/active_support/notifications/event.rb +0 -76
  836. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +0 -68
  837. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +0 -164
  838. data/lib/ddtrace/contrib/active_support/patcher.rb +0 -24
  839. data/lib/ddtrace/contrib/analytics.rb +0 -25
  840. data/lib/ddtrace/contrib/auto_instrument.rb +0 -48
  841. data/lib/ddtrace/contrib/aws/configuration/settings.rb +0 -31
  842. data/lib/ddtrace/contrib/aws/ext.rb +0 -24
  843. data/lib/ddtrace/contrib/aws/instrumentation.rb +0 -91
  844. data/lib/ddtrace/contrib/aws/integration.rb +0 -43
  845. data/lib/ddtrace/contrib/aws/parsed_context.rb +0 -57
  846. data/lib/ddtrace/contrib/aws/patcher.rb +0 -54
  847. data/lib/ddtrace/contrib/aws/services.rb +0 -119
  848. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +0 -21
  849. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +0 -42
  850. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +0 -13
  851. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +0 -24
  852. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +0 -39
  853. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +0 -30
  854. data/lib/ddtrace/contrib/configurable.rb +0 -103
  855. data/lib/ddtrace/contrib/configuration/resolver.rb +0 -82
  856. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +0 -40
  857. data/lib/ddtrace/contrib/configuration/settings.rb +0 -56
  858. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +0 -31
  859. data/lib/ddtrace/contrib/dalli/ext.rb +0 -21
  860. data/lib/ddtrace/contrib/dalli/instrumentation.rb +0 -55
  861. data/lib/ddtrace/contrib/dalli/integration.rb +0 -39
  862. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -26
  863. data/lib/ddtrace/contrib/dalli/quantize.rb +0 -23
  864. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +0 -33
  865. data/lib/ddtrace/contrib/delayed_job/ext.rb +0 -24
  866. data/lib/ddtrace/contrib/delayed_job/integration.rb +0 -39
  867. data/lib/ddtrace/contrib/delayed_job/patcher.rb +0 -29
  868. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -85
  869. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +0 -32
  870. data/lib/ddtrace/contrib/elasticsearch/ext.rb +0 -23
  871. data/lib/ddtrace/contrib/elasticsearch/integration.rb +0 -40
  872. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +0 -123
  873. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +0 -84
  874. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +0 -33
  875. data/lib/ddtrace/contrib/ethon/easy_patch.rb +0 -152
  876. data/lib/ddtrace/contrib/ethon/ext.rb +0 -20
  877. data/lib/ddtrace/contrib/ethon/integration.rb +0 -44
  878. data/lib/ddtrace/contrib/ethon/multi_patch.rb +0 -85
  879. data/lib/ddtrace/contrib/ethon/patcher.rb +0 -27
  880. data/lib/ddtrace/contrib/excon/configuration/settings.rb +0 -34
  881. data/lib/ddtrace/contrib/excon/ext.rb +0 -18
  882. data/lib/ddtrace/contrib/excon/integration.rb +0 -44
  883. data/lib/ddtrace/contrib/excon/middleware.rb +0 -164
  884. data/lib/ddtrace/contrib/excon/patcher.rb +0 -28
  885. data/lib/ddtrace/contrib/extensions.rb +0 -169
  886. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +0 -39
  887. data/lib/ddtrace/contrib/faraday/connection.rb +0 -19
  888. data/lib/ddtrace/contrib/faraday/ext.rb +0 -18
  889. data/lib/ddtrace/contrib/faraday/integration.rb +0 -44
  890. data/lib/ddtrace/contrib/faraday/middleware.rb +0 -86
  891. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -54
  892. data/lib/ddtrace/contrib/faraday/rack_builder.rb +0 -19
  893. data/lib/ddtrace/contrib/grape/configuration/settings.rb +0 -39
  894. data/lib/ddtrace/contrib/grape/endpoint.rb +0 -246
  895. data/lib/ddtrace/contrib/grape/ext.rb +0 -24
  896. data/lib/ddtrace/contrib/grape/instrumentation.rb +0 -34
  897. data/lib/ddtrace/contrib/grape/integration.rb +0 -40
  898. data/lib/ddtrace/contrib/grape/patcher.rb +0 -32
  899. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +0 -33
  900. data/lib/ddtrace/contrib/graphql/ext.rb +0 -17
  901. data/lib/ddtrace/contrib/graphql/integration.rb +0 -40
  902. data/lib/ddtrace/contrib/graphql/patcher.rb +0 -61
  903. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +0 -32
  904. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +0 -59
  905. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +0 -80
  906. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +0 -79
  907. data/lib/ddtrace/contrib/grpc/ext.rb +0 -19
  908. data/lib/ddtrace/contrib/grpc/integration.rb +0 -39
  909. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +0 -50
  910. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -34
  911. data/lib/ddtrace/contrib/http/circuit_breaker.rb +0 -38
  912. data/lib/ddtrace/contrib/http/configuration/settings.rb +0 -33
  913. data/lib/ddtrace/contrib/http/ext.rb +0 -18
  914. data/lib/ddtrace/contrib/http/instrumentation.rb +0 -180
  915. data/lib/ddtrace/contrib/http/integration.rb +0 -46
  916. data/lib/ddtrace/contrib/http/patcher.rb +0 -27
  917. data/lib/ddtrace/contrib/http_annotation_helper.rb +0 -11
  918. data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +0 -33
  919. data/lib/ddtrace/contrib/httpclient/ext.rb +0 -18
  920. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +0 -148
  921. data/lib/ddtrace/contrib/httpclient/integration.rb +0 -44
  922. data/lib/ddtrace/contrib/httpclient/patcher.rb +0 -39
  923. data/lib/ddtrace/contrib/httprb/configuration/settings.rb +0 -33
  924. data/lib/ddtrace/contrib/httprb/ext.rb +0 -18
  925. data/lib/ddtrace/contrib/httprb/instrumentation.rb +0 -158
  926. data/lib/ddtrace/contrib/httprb/integration.rb +0 -44
  927. data/lib/ddtrace/contrib/httprb/patcher.rb +0 -39
  928. data/lib/ddtrace/contrib/integration.rb +0 -17
  929. data/lib/ddtrace/contrib/kafka/configuration/settings.rb +0 -31
  930. data/lib/ddtrace/contrib/kafka/consumer_event.rb +0 -15
  931. data/lib/ddtrace/contrib/kafka/consumer_group_event.rb +0 -15
  932. data/lib/ddtrace/contrib/kafka/event.rb +0 -52
  933. data/lib/ddtrace/contrib/kafka/events/connection/request.rb +0 -35
  934. data/lib/ddtrace/contrib/kafka/events/consumer/process_batch.rb +0 -42
  935. data/lib/ddtrace/contrib/kafka/events/consumer/process_message.rb +0 -40
  936. data/lib/ddtrace/contrib/kafka/events/consumer_group/heartbeat.rb +0 -40
  937. data/lib/ddtrace/contrib/kafka/events/consumer_group/join_group.rb +0 -30
  938. data/lib/ddtrace/contrib/kafka/events/consumer_group/leave_group.rb +0 -30
  939. data/lib/ddtrace/contrib/kafka/events/consumer_group/sync_group.rb +0 -30
  940. data/lib/ddtrace/contrib/kafka/events/produce_operation/send_messages.rb +0 -33
  941. data/lib/ddtrace/contrib/kafka/events/producer/deliver_messages.rb +0 -36
  942. data/lib/ddtrace/contrib/kafka/events.rb +0 -45
  943. data/lib/ddtrace/contrib/kafka/ext.rb +0 -42
  944. data/lib/ddtrace/contrib/kafka/integration.rb +0 -40
  945. data/lib/ddtrace/contrib/kafka/patcher.rb +0 -27
  946. data/lib/ddtrace/contrib/lograge/configuration/settings.rb +0 -19
  947. data/lib/ddtrace/contrib/lograge/ext.rb +0 -11
  948. data/lib/ddtrace/contrib/lograge/instrumentation.rb +0 -39
  949. data/lib/ddtrace/contrib/lograge/integration.rb +0 -46
  950. data/lib/ddtrace/contrib/lograge/patcher.rb +0 -26
  951. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +0 -34
  952. data/lib/ddtrace/contrib/mongodb/ext.rb +0 -24
  953. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +0 -70
  954. data/lib/ddtrace/contrib/mongodb/integration.rb +0 -44
  955. data/lib/ddtrace/contrib/mongodb/parsers.rb +0 -69
  956. data/lib/ddtrace/contrib/mongodb/patcher.rb +0 -32
  957. data/lib/ddtrace/contrib/mongodb/subscribers.rb +0 -112
  958. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +0 -31
  959. data/lib/ddtrace/contrib/mysql2/ext.rb +0 -19
  960. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +0 -65
  961. data/lib/ddtrace/contrib/mysql2/integration.rb +0 -39
  962. data/lib/ddtrace/contrib/mysql2/patcher.rb +0 -28
  963. data/lib/ddtrace/contrib/patchable.rb +0 -71
  964. data/lib/ddtrace/contrib/patcher.rb +0 -66
  965. data/lib/ddtrace/contrib/presto/configuration/settings.rb +0 -31
  966. data/lib/ddtrace/contrib/presto/ext.rb +0 -29
  967. data/lib/ddtrace/contrib/presto/instrumentation.rb +0 -111
  968. data/lib/ddtrace/contrib/presto/integration.rb +0 -39
  969. data/lib/ddtrace/contrib/presto/patcher.rb +0 -34
  970. data/lib/ddtrace/contrib/qless/configuration/settings.rb +0 -36
  971. data/lib/ddtrace/contrib/qless/ext.rb +0 -21
  972. data/lib/ddtrace/contrib/qless/integration.rb +0 -39
  973. data/lib/ddtrace/contrib/qless/patcher.rb +0 -35
  974. data/lib/ddtrace/contrib/qless/qless_job.rb +0 -74
  975. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +0 -34
  976. data/lib/ddtrace/contrib/que/configuration/settings.rb +0 -44
  977. data/lib/ddtrace/contrib/que/ext.rb +0 -31
  978. data/lib/ddtrace/contrib/que/integration.rb +0 -43
  979. data/lib/ddtrace/contrib/que/patcher.rb +0 -25
  980. data/lib/ddtrace/contrib/que/tracer.rb +0 -58
  981. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +0 -31
  982. data/lib/ddtrace/contrib/racecar/event.rb +0 -77
  983. data/lib/ddtrace/contrib/racecar/events/batch.rb +0 -28
  984. data/lib/ddtrace/contrib/racecar/events/consume.rb +0 -28
  985. data/lib/ddtrace/contrib/racecar/events/message.rb +0 -28
  986. data/lib/ddtrace/contrib/racecar/events.rb +0 -33
  987. data/lib/ddtrace/contrib/racecar/ext.rb +0 -26
  988. data/lib/ddtrace/contrib/racecar/integration.rb +0 -40
  989. data/lib/ddtrace/contrib/racecar/patcher.rb +0 -27
  990. data/lib/ddtrace/contrib/rack/configuration/settings.rb +0 -47
  991. data/lib/ddtrace/contrib/rack/ext.rb +0 -22
  992. data/lib/ddtrace/contrib/rack/integration.rb +0 -46
  993. data/lib/ddtrace/contrib/rack/middlewares.rb +0 -288
  994. data/lib/ddtrace/contrib/rack/patcher.rb +0 -106
  995. data/lib/ddtrace/contrib/rack/request_queue.rb +0 -45
  996. data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +0 -10
  997. data/lib/ddtrace/contrib/rails/configuration/settings.rb +0 -101
  998. data/lib/ddtrace/contrib/rails/ext.rb +0 -18
  999. data/lib/ddtrace/contrib/rails/framework.rb +0 -172
  1000. data/lib/ddtrace/contrib/rails/integration.rb +0 -45
  1001. data/lib/ddtrace/contrib/rails/log_injection.rb +0 -42
  1002. data/lib/ddtrace/contrib/rails/middlewares.rb +0 -44
  1003. data/lib/ddtrace/contrib/rails/patcher.rb +0 -119
  1004. data/lib/ddtrace/contrib/rails/railtie.rb +0 -18
  1005. data/lib/ddtrace/contrib/rails/utils.rb +0 -25
  1006. data/lib/ddtrace/contrib/rake/configuration/settings.rb +0 -32
  1007. data/lib/ddtrace/contrib/rake/ext.rb +0 -22
  1008. data/lib/ddtrace/contrib/rake/instrumentation.rb +0 -91
  1009. data/lib/ddtrace/contrib/rake/integration.rb +0 -39
  1010. data/lib/ddtrace/contrib/rake/patcher.rb +0 -31
  1011. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +0 -46
  1012. data/lib/ddtrace/contrib/redis/configuration/settings.rb +0 -36
  1013. data/lib/ddtrace/contrib/redis/ext.rb +0 -23
  1014. data/lib/ddtrace/contrib/redis/instrumentation.rb +0 -90
  1015. data/lib/ddtrace/contrib/redis/integration.rb +0 -43
  1016. data/lib/ddtrace/contrib/redis/patcher.rb +0 -33
  1017. data/lib/ddtrace/contrib/redis/quantize.rb +0 -76
  1018. data/lib/ddtrace/contrib/redis/tags.rb +0 -47
  1019. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +0 -159
  1020. data/lib/ddtrace/contrib/registerable.rb +0 -33
  1021. data/lib/ddtrace/contrib/registry.rb +0 -43
  1022. data/lib/ddtrace/contrib/resque/configuration/settings.rb +0 -49
  1023. data/lib/ddtrace/contrib/resque/ext.rb +0 -18
  1024. data/lib/ddtrace/contrib/resque/integration.rb +0 -44
  1025. data/lib/ddtrace/contrib/resque/patcher.rb +0 -30
  1026. data/lib/ddtrace/contrib/resque/resque_job.rb +0 -104
  1027. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +0 -32
  1028. data/lib/ddtrace/contrib/rest_client/ext.rb +0 -18
  1029. data/lib/ddtrace/contrib/rest_client/integration.rb +0 -39
  1030. data/lib/ddtrace/contrib/rest_client/patcher.rb +0 -25
  1031. data/lib/ddtrace/contrib/rest_client/request_patch.rb +0 -92
  1032. data/lib/ddtrace/contrib/semantic_logger/configuration/settings.rb +0 -19
  1033. data/lib/ddtrace/contrib/semantic_logger/ext.rb +0 -11
  1034. data/lib/ddtrace/contrib/semantic_logger/instrumentation.rb +0 -43
  1035. data/lib/ddtrace/contrib/semantic_logger/integration.rb +0 -48
  1036. data/lib/ddtrace/contrib/semantic_logger/patcher.rb +0 -26
  1037. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +0 -29
  1038. data/lib/ddtrace/contrib/sequel/database.rb +0 -64
  1039. data/lib/ddtrace/contrib/sequel/dataset.rb +0 -64
  1040. data/lib/ddtrace/contrib/sequel/ext.rb +0 -20
  1041. data/lib/ddtrace/contrib/sequel/integration.rb +0 -39
  1042. data/lib/ddtrace/contrib/sequel/patcher.rb +0 -34
  1043. data/lib/ddtrace/contrib/sequel/utils.rb +0 -75
  1044. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +0 -32
  1045. data/lib/ddtrace/contrib/shoryuken/ext.rb +0 -22
  1046. data/lib/ddtrace/contrib/shoryuken/integration.rb +0 -40
  1047. data/lib/ddtrace/contrib/shoryuken/patcher.rb +0 -25
  1048. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -56
  1049. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +0 -44
  1050. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +0 -38
  1051. data/lib/ddtrace/contrib/sidekiq/ext.rb +0 -31
  1052. data/lib/ddtrace/contrib/sidekiq/integration.rb +0 -49
  1053. data/lib/ddtrace/contrib/sidekiq/patcher.rb +0 -68
  1054. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/heartbeat.rb +0 -30
  1055. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/job_fetch.rb +0 -30
  1056. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +0 -29
  1057. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +0 -66
  1058. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -45
  1059. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +0 -40
  1060. data/lib/ddtrace/contrib/sinatra/env.rb +0 -59
  1061. data/lib/ddtrace/contrib/sinatra/ext.rb +0 -28
  1062. data/lib/ddtrace/contrib/sinatra/headers.rb +0 -30
  1063. data/lib/ddtrace/contrib/sinatra/integration.rb +0 -39
  1064. data/lib/ddtrace/contrib/sinatra/patcher.rb +0 -30
  1065. data/lib/ddtrace/contrib/sinatra/tracer.rb +0 -150
  1066. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +0 -112
  1067. data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +0 -34
  1068. data/lib/ddtrace/contrib/sneakers/ext.rb +0 -23
  1069. data/lib/ddtrace/contrib/sneakers/integration.rb +0 -42
  1070. data/lib/ddtrace/contrib/sneakers/patcher.rb +0 -25
  1071. data/lib/ddtrace/contrib/sneakers/tracer.rb +0 -54
  1072. data/lib/ddtrace/contrib/status_code_matcher.rb +0 -70
  1073. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +0 -31
  1074. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +0 -25
  1075. data/lib/ddtrace/contrib/sucker_punch/ext.rb +0 -22
  1076. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +0 -89
  1077. data/lib/ddtrace/contrib/sucker_punch/integration.rb +0 -39
  1078. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +0 -44
  1079. data/lib/ddtrace/correlation.rb +0 -40
  1080. data/lib/ddtrace/diagnostics/environment_logger.rb +0 -280
  1081. data/lib/ddtrace/diagnostics/health.rb +0 -34
  1082. data/lib/ddtrace/distributed_tracing/headers/b3.rb +0 -45
  1083. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +0 -57
  1084. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +0 -43
  1085. data/lib/ddtrace/distributed_tracing/headers/headers.rb +0 -72
  1086. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +0 -44
  1087. data/lib/ddtrace/encoding.rb +0 -72
  1088. data/lib/ddtrace/error.rb +0 -97
  1089. data/lib/ddtrace/event.rb +0 -53
  1090. data/lib/ddtrace/ext/analytics.rb +0 -13
  1091. data/lib/ddtrace/ext/app_types.rb +0 -12
  1092. data/lib/ddtrace/ext/correlation.rb +0 -12
  1093. data/lib/ddtrace/ext/diagnostics.rb +0 -37
  1094. data/lib/ddtrace/ext/distributed.rb +0 -40
  1095. data/lib/ddtrace/ext/environment.rb +0 -24
  1096. data/lib/ddtrace/ext/errors.rb +0 -11
  1097. data/lib/ddtrace/ext/forced_tracing.rb +0 -26
  1098. data/lib/ddtrace/ext/git.rb +0 -32
  1099. data/lib/ddtrace/ext/http.rb +0 -47
  1100. data/lib/ddtrace/ext/integration.rb +0 -9
  1101. data/lib/ddtrace/ext/manual_tracing.rb +0 -10
  1102. data/lib/ddtrace/ext/metrics.rb +0 -16
  1103. data/lib/ddtrace/ext/net.rb +0 -11
  1104. data/lib/ddtrace/ext/priority.rb +0 -19
  1105. data/lib/ddtrace/ext/profiling.rb +0 -53
  1106. data/lib/ddtrace/ext/runtime.rb +0 -25
  1107. data/lib/ddtrace/ext/sampling.rb +0 -17
  1108. data/lib/ddtrace/ext/sql.rb +0 -9
  1109. data/lib/ddtrace/ext/test.rb +0 -9
  1110. data/lib/ddtrace/ext/transport.rb +0 -32
  1111. data/lib/ddtrace/forced_tracing.rb +0 -39
  1112. data/lib/ddtrace/logger.rb +0 -41
  1113. data/lib/ddtrace/metrics.rb +0 -282
  1114. data/lib/ddtrace/opentelemetry/extensions.rb +0 -14
  1115. data/lib/ddtrace/opentelemetry/span.rb +0 -34
  1116. data/lib/ddtrace/opentracer/binary_propagator.rb +0 -25
  1117. data/lib/ddtrace/opentracer/carrier.rb +0 -7
  1118. data/lib/ddtrace/opentracer/distributed_headers.rb +0 -56
  1119. data/lib/ddtrace/opentracer/global_tracer.rb +0 -16
  1120. data/lib/ddtrace/opentracer/propagator.rb +0 -23
  1121. data/lib/ddtrace/opentracer/rack_propagator.rb +0 -61
  1122. data/lib/ddtrace/opentracer/scope.rb +0 -16
  1123. data/lib/ddtrace/opentracer/scope_manager.rb +0 -7
  1124. data/lib/ddtrace/opentracer/span.rb +0 -95
  1125. data/lib/ddtrace/opentracer/span_context.rb +0 -15
  1126. data/lib/ddtrace/opentracer/span_context_factory.rb +0 -24
  1127. data/lib/ddtrace/opentracer/text_map_propagator.rb +0 -76
  1128. data/lib/ddtrace/opentracer/thread_local_scope.rb +0 -32
  1129. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +0 -41
  1130. data/lib/ddtrace/opentracer/tracer.rb +0 -209
  1131. data/lib/ddtrace/opentracer.rb +0 -22
  1132. data/lib/ddtrace/patcher.rb +0 -69
  1133. data/lib/ddtrace/pin.rb +0 -86
  1134. data/lib/ddtrace/pipeline/span_filter.rb +0 -39
  1135. data/lib/ddtrace/pipeline/span_processor.rb +0 -21
  1136. data/lib/ddtrace/pipeline.rb +0 -47
  1137. data/lib/ddtrace/profiling/backtrace_location.rb +0 -33
  1138. data/lib/ddtrace/profiling/buffer.rb +0 -42
  1139. data/lib/ddtrace/profiling/collectors/stack.rb +0 -297
  1140. data/lib/ddtrace/profiling/encoding/profile.rb +0 -46
  1141. data/lib/ddtrace/profiling/event.rb +0 -14
  1142. data/lib/ddtrace/profiling/events/stack.rb +0 -81
  1143. data/lib/ddtrace/profiling/exporter.rb +0 -24
  1144. data/lib/ddtrace/profiling/ext/forking.rb +0 -98
  1145. data/lib/ddtrace/profiling/flush.rb +0 -44
  1146. data/lib/ddtrace/profiling/native_extension.rb +0 -40
  1147. data/lib/ddtrace/profiling/pprof/builder.rb +0 -126
  1148. data/lib/ddtrace/profiling/pprof/converter.rb +0 -103
  1149. data/lib/ddtrace/profiling/pprof/message_set.rb +0 -15
  1150. data/lib/ddtrace/profiling/pprof/payload.rb +0 -19
  1151. data/lib/ddtrace/profiling/pprof/pprof_pb.rb +0 -82
  1152. data/lib/ddtrace/profiling/pprof/stack_sample.rb +0 -140
  1153. data/lib/ddtrace/profiling/pprof/string_table.rb +0 -11
  1154. data/lib/ddtrace/profiling/pprof/template.rb +0 -119
  1155. data/lib/ddtrace/profiling/profiler.rb +0 -31
  1156. data/lib/ddtrace/profiling/recorder.rb +0 -96
  1157. data/lib/ddtrace/profiling/scheduler.rb +0 -150
  1158. data/lib/ddtrace/profiling/tasks/setup.rb +0 -90
  1159. data/lib/ddtrace/profiling/trace_identifiers/ddtrace.rb +0 -42
  1160. data/lib/ddtrace/profiling/trace_identifiers/helper.rb +0 -46
  1161. data/lib/ddtrace/profiling/transport/client.rb +0 -15
  1162. data/lib/ddtrace/profiling/transport/http/api/endpoint.rb +0 -94
  1163. data/lib/ddtrace/profiling/transport/http/api/instance.rb +0 -37
  1164. data/lib/ddtrace/profiling/transport/http/api/spec.rb +0 -41
  1165. data/lib/ddtrace/profiling/transport/http/api.rb +0 -44
  1166. data/lib/ddtrace/profiling/transport/http/builder.rb +0 -29
  1167. data/lib/ddtrace/profiling/transport/http/client.rb +0 -34
  1168. data/lib/ddtrace/profiling/transport/http/response.rb +0 -22
  1169. data/lib/ddtrace/profiling/transport/http.rb +0 -111
  1170. data/lib/ddtrace/profiling/transport/io/client.rb +0 -28
  1171. data/lib/ddtrace/profiling/transport/io/response.rb +0 -17
  1172. data/lib/ddtrace/profiling/transport/io.rb +0 -31
  1173. data/lib/ddtrace/profiling/transport/parcel.rb +0 -18
  1174. data/lib/ddtrace/profiling/transport/request.rb +0 -16
  1175. data/lib/ddtrace/profiling/transport/response.rb +0 -9
  1176. data/lib/ddtrace/profiling.rb +0 -149
  1177. data/lib/ddtrace/propagation/grpc_propagator.rb +0 -75
  1178. data/lib/ddtrace/propagation/http_propagator.rb +0 -91
  1179. data/lib/ddtrace/quantization/hash.rb +0 -104
  1180. data/lib/ddtrace/quantization/http.rb +0 -90
  1181. data/lib/ddtrace/runtime/metrics.rb +0 -135
  1182. data/lib/ddtrace/sampler.rb +0 -303
  1183. data/lib/ddtrace/sampling/matcher.rb +0 -58
  1184. data/lib/ddtrace/sampling/rate_limiter.rb +0 -177
  1185. data/lib/ddtrace/sampling/rule.rb +0 -62
  1186. data/lib/ddtrace/sampling/rule_sampler.rb +0 -133
  1187. data/lib/ddtrace/sampling.rb +0 -3
  1188. data/lib/ddtrace/span.rb +0 -445
  1189. data/lib/ddtrace/sync_writer.rb +0 -69
  1190. data/lib/ddtrace/tasks/exec.rb +0 -47
  1191. data/lib/ddtrace/tasks/help.rb +0 -15
  1192. data/lib/ddtrace/tracer.rb +0 -449
  1193. data/lib/ddtrace/utils/compression.rb +0 -28
  1194. data/lib/ddtrace/utils/database.rb +0 -26
  1195. data/lib/ddtrace/utils/forking.rb +0 -53
  1196. data/lib/ddtrace/utils/object_set.rb +0 -40
  1197. data/lib/ddtrace/utils/only_once.rb +0 -41
  1198. data/lib/ddtrace/utils/sequence.rb +0 -18
  1199. data/lib/ddtrace/utils/string_table.rb +0 -46
  1200. data/lib/ddtrace/utils/time.rb +0 -51
  1201. data/lib/ddtrace/utils.rb +0 -80
  1202. data/lib/ddtrace/vendor/active_record/connection_specification.rb +0 -302
  1203. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +0 -117
  1204. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +0 -58
  1205. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +0 -136
  1206. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +0 -10
  1207. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +0 -9
  1208. data/lib/ddtrace/vendor/multipart-post/multipart.rb +0 -13
  1209. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +0 -33
  1210. data/lib/ddtrace/worker.rb +0 -21
  1211. data/lib/ddtrace/workers/async.rb +0 -175
  1212. data/lib/ddtrace/workers/interval_loop.rb +0 -116
  1213. data/lib/ddtrace/workers/polling.rb +0 -56
  1214. data/lib/ddtrace/workers/queue.rb +0 -41
  1215. data/lib/ddtrace/workers/runtime_metrics.rb +0 -65
  1216. data/lib/ddtrace/workers/trace_writer.rb +0 -200
  1217. data/lib/ddtrace/workers.rb +0 -123
  1218. data/lib/ddtrace/writer.rb +0 -200
  1219. /data/lib/{ddtrace → datadog/core}/vendor/multipart-post/LICENSE +0 -0
  1220. /data/lib/{ddtrace → datadog}/profiling/pprof/pprof.proto +0 -0
  1221. /data/lib/{ddtrace/vendor/active_record → datadog/tracing/contrib/active_record/vendor}/MIT-LICENSE +0 -0
  1222. /data/lib/{ddtrace → datadog/tracing}/contrib/redis/vendor/LICENSE +0 -0
@@ -0,0 +1,301 @@
1
+ require_relative '../../core/utils/only_once'
2
+ require_relative '../../core/utils/time'
3
+ require_relative '../../core/worker'
4
+ require_relative '../../core/workers/polling'
5
+ require_relative '../backtrace_location'
6
+ require_relative '../events/stack'
7
+ require_relative '../native_extension'
8
+
9
+ module Datadog
10
+ module Profiling
11
+ module Collectors
12
+ # Collects stack trace samples from Ruby threads for both CPU-time (if available) and wall-clock.
13
+ # Runs on its own background thread.
14
+ #
15
+ # This class has the prefix "Old" because it will be deprecated by the new native CPU Profiler
16
+ class OldStack < Core::Worker
17
+ include Core::Workers::Polling
18
+
19
+ DEFAULT_MAX_TIME_USAGE_PCT = 2.0
20
+ MIN_INTERVAL = 0.01
21
+ THREAD_LAST_CPU_TIME_KEY = :datadog_profiler_last_cpu_time
22
+ THREAD_LAST_WALL_CLOCK_KEY = :datadog_profiler_last_wall_clock
23
+ SYNTHETIC_STACK_IN_NATIVE_CODE = [BacktraceLocation.new('', 0, 'In native code').freeze].freeze
24
+
25
+ # This default was picked based on the current sampling performance and on expected concurrency on an average
26
+ # Ruby MRI application. Lowering this optimizes for latency (less impact each time we sample), and raising
27
+ # optimizes for coverage (less chance to miss what a given thread is doing).
28
+ DEFAULT_MAX_THREADS_SAMPLED = 16
29
+
30
+ attr_reader \
31
+ :recorder,
32
+ :max_frames,
33
+ :trace_identifiers_helper,
34
+ :ignore_thread,
35
+ :max_time_usage_pct,
36
+ :thread_api,
37
+ :cpu_time_provider
38
+
39
+ def initialize(
40
+ recorder,
41
+ max_frames:,
42
+ trace_identifiers_helper:, # Usually an instance of Profiling::TraceIdentifiers::Helper
43
+ ignore_thread: nil,
44
+ max_time_usage_pct: DEFAULT_MAX_TIME_USAGE_PCT,
45
+ max_threads_sampled: DEFAULT_MAX_THREADS_SAMPLED,
46
+ thread_api: Thread,
47
+ cpu_time_provider: Profiling::NativeExtension,
48
+ fork_policy: Core::Workers::Async::Thread::FORK_POLICY_RESTART, # Restart in forks by default
49
+ interval: MIN_INTERVAL,
50
+ enabled: true
51
+ )
52
+ @recorder = recorder
53
+ @max_frames = max_frames
54
+ @trace_identifiers_helper = trace_identifiers_helper
55
+ @ignore_thread = ignore_thread
56
+ @max_time_usage_pct = max_time_usage_pct
57
+ @max_threads_sampled = max_threads_sampled
58
+ @thread_api = thread_api
59
+ # Only set the provider if it's able to work in the current Ruby/OS combo
60
+ @cpu_time_provider = cpu_time_provider unless cpu_time_provider.cpu_time_ns_for(thread_api.current).nil?
61
+
62
+ # Workers::Async::Thread settings
63
+ self.fork_policy = fork_policy
64
+
65
+ # Workers::IntervalLoop settings
66
+ self.loop_base_interval = interval
67
+
68
+ # Workers::Polling settings
69
+ self.enabled = enabled
70
+
71
+ # Cache this proc, since it's pretty expensive to keep recreating it
72
+ @build_backtrace_location = method(:build_backtrace_location).to_proc
73
+ # Cache this buffer, since it's pretty expensive to keep accessing it
74
+ @stack_sample_event_recorder = recorder[Events::StackSample]
75
+ # See below for details on why this is needed
76
+ @needs_process_waiter_workaround = Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.7')
77
+ end
78
+
79
+ def start
80
+ reset_cpu_time_tracking
81
+ perform
82
+ end
83
+
84
+ def perform
85
+ collect_and_wait
86
+ end
87
+
88
+ def collect_and_wait
89
+ run_time = Core::Utils::Time.measure do
90
+ collect_events
91
+ end
92
+
93
+ # Update wait time to throttle profiling
94
+ self.loop_wait_time = compute_wait_time(run_time)
95
+ end
96
+
97
+ def collect_events
98
+ events = []
99
+ current_wall_time_ns = get_current_wall_time_timestamp_ns
100
+
101
+ # Collect backtraces from each thread
102
+ threads_to_sample.each do |thread|
103
+ next unless thread.alive?
104
+ next if ignore_thread.is_a?(Proc) && ignore_thread.call(thread)
105
+
106
+ event = collect_thread_event(thread, current_wall_time_ns)
107
+ events << event unless event.nil?
108
+ end
109
+
110
+ # Send events to recorder
111
+ recorder.push(events) unless events.empty?
112
+
113
+ events
114
+ end
115
+
116
+ def collect_thread_event(thread, current_wall_time_ns)
117
+ locations = thread.backtrace_locations
118
+ return if locations.nil?
119
+
120
+ # Having empty locations means that the thread is alive, but we don't know what it's doing:
121
+ #
122
+ # 1. It can be starting up
123
+ # ```
124
+ # > Thread.new { sleep }.backtrace
125
+ # => [] # <-- note the thread hasn't actually started running sleep yet, we got there first
126
+ # ```
127
+ # 2. It can be running native code
128
+ # ```
129
+ # > t = Process.detach(fork { sleep })
130
+ # => #<Process::Waiter:0x00007ffe7285f7a0 run>
131
+ # > t.backtrace
132
+ # => [] # <-- this can happen even minutes later, e.g. it's not a race as in 1.
133
+ # ```
134
+ # This effect has been observed in threads created by the Iodine web server and the ffi gem
135
+ #
136
+ # To give customers visibility into these threads, we replace the empty stack with one containing a
137
+ # synthetic placeholder frame, so that these threads are properly represented in the UX.
138
+ locations = SYNTHETIC_STACK_IN_NATIVE_CODE if locations.empty?
139
+
140
+ # Get actual stack size then trim the stack
141
+ stack_size = locations.length
142
+ locations = locations[0..(max_frames - 1)]
143
+
144
+ # Convert backtrace locations into structs
145
+ locations = convert_backtrace_locations(locations)
146
+
147
+ thread_id = thread.object_id
148
+ root_span_id, span_id, trace_resource = trace_identifiers_helper.trace_identifiers_for(thread)
149
+ cpu_time = get_cpu_time_interval!(thread)
150
+ wall_time_interval_ns =
151
+ get_elapsed_since_last_sample_and_set_value(thread, THREAD_LAST_WALL_CLOCK_KEY, current_wall_time_ns)
152
+
153
+ Events::StackSample.new(
154
+ nil,
155
+ locations,
156
+ stack_size,
157
+ thread_id,
158
+ root_span_id,
159
+ span_id,
160
+ trace_resource,
161
+ cpu_time,
162
+ wall_time_interval_ns
163
+ )
164
+ end
165
+
166
+ def get_cpu_time_interval!(thread)
167
+ return unless cpu_time_provider
168
+
169
+ current_cpu_time_ns = cpu_time_provider.cpu_time_ns_for(thread)
170
+
171
+ return unless current_cpu_time_ns
172
+
173
+ get_elapsed_since_last_sample_and_set_value(thread, THREAD_LAST_CPU_TIME_KEY, current_cpu_time_ns)
174
+ end
175
+
176
+ def compute_wait_time(used_time)
177
+ # We took used_time to get the last sample.
178
+ #
179
+ # What we're computing here is -- if used_time corresponds to max_time_usage_pct of the time we should
180
+ # spend working, how much is (100% - max_time_usage_pct) of the time?
181
+ #
182
+ # For instance, if we took 10ms to sample, and max_time_usage_pct is 1%, then the other 99% is 990ms, which
183
+ # means we need to sleep for 990ms to guarantee that we don't spend more than 1% of the time working.
184
+ used_time_ns = used_time * 1e9
185
+ interval = (used_time_ns / (max_time_usage_pct / 100.0)) - used_time_ns
186
+ [interval / 1e9, MIN_INTERVAL].max
187
+ end
188
+
189
+ # Convert backtrace locations into structs
190
+ # Re-use old backtrace location objects if they already exist in the buffer
191
+ def convert_backtrace_locations(locations)
192
+ locations.collect do |location|
193
+ # Re-use existing BacktraceLocation if identical copy, otherwise build a new one.
194
+ @stack_sample_event_recorder.cache(:backtrace_locations).fetch(
195
+ # Function name
196
+ location.base_label,
197
+ # Line number
198
+ location.lineno,
199
+ # Filename
200
+ location.path,
201
+ # Build function
202
+ &@build_backtrace_location
203
+ )
204
+ end
205
+ end
206
+
207
+ def build_backtrace_location(_id, base_label, lineno, path)
208
+ string_table = @stack_sample_event_recorder.string_table
209
+
210
+ Profiling::BacktraceLocation.new(
211
+ string_table.fetch_string(base_label),
212
+ lineno,
213
+ string_table.fetch_string(path)
214
+ )
215
+ end
216
+
217
+ def reset_after_fork
218
+ recorder.reset_after_fork
219
+
220
+ # NOTE: We could perhaps also call #reset_cpu_time_tracking here, although it's not needed because we always
221
+ # call in in #start.
222
+ end
223
+
224
+ private
225
+
226
+ # If the profiler is started for a while, stopped and then restarted OR whenever the process forks, we need to
227
+ # clean up any leftover per-thread counters, so that the first sample after starting doesn't end up with:
228
+ #
229
+ # a) negative time: At least on my test docker container, and on the reliability environment, after the process
230
+ # forks, the cpu time reference changes and (old cpu time - new cpu time) can be < 0
231
+ #
232
+ # b) large amount of time: if the profiler was started, then stopped for some amount of time, and then
233
+ # restarted, we don't want the first sample to be "blamed" for multiple minutes of CPU time
234
+ #
235
+ # By resetting the last cpu time seen, we start with a clean slate every time we start the stack collector.
236
+ def reset_cpu_time_tracking
237
+ thread_api.list.each do |thread|
238
+ # See below for details on why this is needed
239
+ next if @needs_process_waiter_workaround && thread.is_a?(::Process::Waiter)
240
+
241
+ thread.thread_variable_set(THREAD_LAST_CPU_TIME_KEY, nil)
242
+ thread.thread_variable_set(THREAD_LAST_WALL_CLOCK_KEY, nil)
243
+ end
244
+ end
245
+
246
+ def get_elapsed_since_last_sample_and_set_value(thread, key, current_value)
247
+ # Process::Waiter crash workaround:
248
+ #
249
+ # This is a workaround for a Ruby VM segfault (usually something like
250
+ # "[BUG] Segmentation fault at 0x0000000000000008") in the affected Ruby versions.
251
+ # See https://bugs.ruby-lang.org/issues/17807 for details.
252
+ #
253
+ # In those Ruby versions, there's a very special subclass of `Thread` called `Process::Waiter` that causes VM
254
+ # crashes whenever something tries to read its instance or thread variables. This subclass of thread only
255
+ # shows up when the `Process.detach` API gets used.
256
+ # In the specs you'll find crash regression tests that include a way of reproducing it.
257
+ #
258
+ # As workaround for now we just skip it for the affected Rubies
259
+ return 0 if @needs_process_waiter_workaround && thread.is_a?(::Process::Waiter)
260
+
261
+ last_value = thread.thread_variable_get(key) || current_value
262
+ thread.thread_variable_set(key, current_value)
263
+
264
+ current_value - last_value
265
+ end
266
+
267
+ # Whenever there are more than max_threads_sampled active, we only sample a subset of them.
268
+ # We do this to avoid impacting the latency of the service being profiled. We want to avoid doing
269
+ # a big burst of work all at once (sample everything), and instead do a little work each time
270
+ # (sample a bit by bit).
271
+ #
272
+ # Because we pick the threads to sample randomly, we'll eventually sample all threads -- just not at once.
273
+ # Notice also that this will interact with our dynamic sampling mechanism -- if samples are faster, we take
274
+ # them more often, if they are slower, we take them less often -- which again means that over a longer period
275
+ # we should take sample roughly the same samples.
276
+ #
277
+ # One downside of this approach is that if there really are many threads, the resulting wall clock times
278
+ # in a one minute profile may "drift" around the 60 second mark, e.g. maybe we only sampled a thread once per
279
+ # second and only 59 times, so we'll report 59s, but on the next report we'll include the missing one, so
280
+ # then the result will be 61s. I've observed 60 +- 1.68 secs for an app with ~65 threads, given the
281
+ # default maximum of 16 threads. This seems a reasonable enough margin of error given the improvement to
282
+ # latency (especially on such a large application! -> even bigger latency impact if we tried to sample all
283
+ # threads).
284
+ #
285
+ def threads_to_sample
286
+ all_threads = thread_api.list
287
+
288
+ if all_threads.size > @max_threads_sampled
289
+ all_threads.sample(@max_threads_sampled)
290
+ else
291
+ all_threads
292
+ end
293
+ end
294
+
295
+ def get_current_wall_time_timestamp_ns
296
+ Core::Utils::Time.get_time(:nanosecond)
297
+ end
298
+ end
299
+ end
300
+ end
301
+ end
@@ -0,0 +1,11 @@
1
+ module Datadog
2
+ module Profiling
3
+ module Collectors
4
+ # Used to gather a stack trace from a given Ruby thread. Stores its output on a `StackRecorder`.
5
+ #
6
+ # This class is not empty; all of this class is implemented as native code.
7
+ class Stack # rubocop:disable Lint/EmptyClass
8
+ end
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,46 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Datadog
4
+ module Profiling
5
+ module Collectors
6
+ # Used to trigger sampling of threads, based on external "events", such as:
7
+ # * periodic timer for cpu-time and wall-time
8
+ # * VM garbage collection events
9
+ # * VM object allocation events
10
+ # Triggering of this component (e.g. watching for the above "events") is implemented by
11
+ # Collectors::CpuAndWallTimeWorker.
12
+ # The stack collection itself is handled using the Datadog::Profiling::Collectors::Stack.
13
+ # Almost all of this class is implemented as native code.
14
+ #
15
+ # Methods prefixed with _native_ are implemented in `collectors_thread_context.c`
16
+ class ThreadContext
17
+ def initialize(recorder:, max_frames:, tracer:)
18
+ tracer_context_key = safely_extract_context_key_from(tracer)
19
+ self.class._native_initialize(self, recorder, max_frames, tracer_context_key)
20
+ end
21
+
22
+ def inspect
23
+ # Compose Ruby's default inspect with our custom inspect for the native parts
24
+ result = super()
25
+ result[-1] = "#{self.class._native_inspect(self)}>"
26
+ result
27
+ end
28
+
29
+ def reset_after_fork
30
+ self.class._native_reset_after_fork(self)
31
+ end
32
+
33
+ private
34
+
35
+ def safely_extract_context_key_from(tracer)
36
+ provider = tracer && tracer.respond_to?(:provider) && tracer.provider
37
+
38
+ return unless provider
39
+
40
+ context = provider.instance_variable_get(:@context)
41
+ context && context.instance_variable_get(:@key)
42
+ end
43
+ end
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,161 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Datadog
4
+ module Profiling
5
+ # Profiling component
6
+ module Component
7
+ def build_profiler(settings, agent_settings, tracer)
8
+ return unless settings.profiling.enabled
9
+
10
+ # Workaround for weird dependency direction: the Core::Configuration::Components class currently has a
11
+ # dependency on individual products, in this case the Profiler.
12
+ # (Note "currently": in the future we want to change this so core classes don't depend on specific products)
13
+ #
14
+ # If the current file included a `require 'datadog/profiler'` at its beginning, we would generate circular
15
+ # requires when used from profiling:
16
+ #
17
+ # datadog/profiling
18
+ # └─requires─> datadog/core
19
+ # └─requires─> datadog/core/configuration/components
20
+ # └─requires─> datadog/profiling # Loop!
21
+ #
22
+ # ...thus in #1998 we removed such a require.
23
+ #
24
+ # On the other hand, if datadog/core is loaded by a different product and no general `require 'ddtrace'` is
25
+ # done, then profiling may not be loaded, and thus to avoid this issue we do a require here (which is a
26
+ # no-op if profiling is already loaded).
27
+ require_relative '../profiling'
28
+ return unless Profiling.supported?
29
+
30
+ unless defined?(Profiling::Tasks::Setup)
31
+ # In #1545 a user reported a NameError due to this constant being uninitialized
32
+ # I've documented my suspicion on why that happened in
33
+ # https://github.com/DataDog/dd-trace-rb/issues/1545#issuecomment-856049025
34
+ #
35
+ # > Thanks for the info! It seems to feed into my theory: there's two moments in the code where we check if
36
+ # > profiler is "supported": 1) when loading ddtrace (inside preload) and 2) when starting the profile
37
+ # > after Datadog.configure gets run.
38
+ # > The problem is that the code assumes that both checks 1) and 2) will always reach the same conclusion:
39
+ # > either profiler is supported, or profiler is not supported.
40
+ # > In the problematic case, it looks like in your case check 1 decides that profiler is not
41
+ # > supported => doesn't load it, and then check 2 decides that it is => assumes it is loaded and tries to
42
+ # > start it.
43
+ #
44
+ # I was never able to validate if this was the issue or why exactly .supported? would change its mind BUT
45
+ # just in case it happens again, I've left this check which avoids breaking the user's application AND
46
+ # would instead direct them to report it to us instead, so that we can investigate what's wrong.
47
+ #
48
+ # TODO: As of June 2021, most checks in .supported? are related to the google-protobuf gem; so it's
49
+ # very likely that it was the origin of the issue we saw. Thus, if, as planned we end up moving away from
50
+ # protobuf OR enough time has passed and no users saw the issue again, we can remove this check altogether.
51
+ Datadog.logger.error(
52
+ 'Profiling was marked as supported and enabled, but setup task was not loaded properly. ' \
53
+ 'Please report this at https://github.com/DataDog/dd-trace-rb/blob/master/CONTRIBUTING.md#found-a-bug'
54
+ )
55
+
56
+ return
57
+ end
58
+
59
+ # Load extensions needed to support some of the Profiling features
60
+ Profiling::Tasks::Setup.new.run
61
+
62
+ # NOTE: Please update the Initialization section of ProfilingDevelopment.md with any changes to this method
63
+
64
+ if settings.profiling.advanced.force_enable_new_profiler
65
+ print_new_profiler_warnings
66
+
67
+ recorder = Datadog::Profiling::StackRecorder.new(
68
+ cpu_time_enabled: RUBY_PLATFORM.include?('linux'), # Only supported on Linux currently
69
+ alloc_samples_enabled: false, # Always disabled for now -- work in progress
70
+ )
71
+ collector = Datadog::Profiling::Collectors::CpuAndWallTimeWorker.new(
72
+ recorder: recorder,
73
+ max_frames: settings.profiling.advanced.max_frames,
74
+ tracer: tracer,
75
+ gc_profiling_enabled: should_enable_gc_profiling?(settings),
76
+ allocation_counting_enabled: settings.profiling.advanced.allocation_counting_enabled,
77
+ )
78
+ else
79
+ trace_identifiers_helper = Profiling::TraceIdentifiers::Helper.new(
80
+ tracer: tracer,
81
+ endpoint_collection_enabled: settings.profiling.advanced.endpoint.collection.enabled
82
+ )
83
+
84
+ recorder = build_profiler_old_recorder(settings)
85
+ collector = build_profiler_oldstack_collector(settings, recorder, trace_identifiers_helper)
86
+ end
87
+
88
+ exporter = build_profiler_exporter(settings, recorder)
89
+ transport = build_profiler_transport(settings, agent_settings)
90
+ scheduler = Profiling::Scheduler.new(exporter: exporter, transport: transport)
91
+
92
+ Profiling::Profiler.new([collector], scheduler)
93
+ end
94
+
95
+ private
96
+
97
+ def build_profiler_old_recorder(settings)
98
+ Profiling::OldRecorder.new([Profiling::Events::StackSample], settings.profiling.advanced.max_events)
99
+ end
100
+
101
+ def build_profiler_exporter(settings, recorder)
102
+ code_provenance_collector =
103
+ (Profiling::Collectors::CodeProvenance.new if settings.profiling.advanced.code_provenance_enabled)
104
+
105
+ Profiling::Exporter.new(pprof_recorder: recorder, code_provenance_collector: code_provenance_collector)
106
+ end
107
+
108
+ def build_profiler_oldstack_collector(settings, old_recorder, trace_identifiers_helper)
109
+ Profiling::Collectors::OldStack.new(
110
+ old_recorder,
111
+ trace_identifiers_helper: trace_identifiers_helper,
112
+ max_frames: settings.profiling.advanced.max_frames
113
+ )
114
+ end
115
+
116
+ def build_profiler_transport(settings, agent_settings)
117
+ settings.profiling.exporter.transport ||
118
+ Profiling::HttpTransport.new(
119
+ agent_settings: agent_settings,
120
+ site: settings.site,
121
+ api_key: settings.api_key,
122
+ upload_timeout_seconds: settings.profiling.upload.timeout_seconds,
123
+ )
124
+ end
125
+
126
+ def should_enable_gc_profiling?(settings)
127
+ # See comments on the setting definition for more context on why it exists.
128
+ if settings.profiling.advanced.force_enable_gc_profiling
129
+ if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new('3')
130
+ Datadog.logger.debug(
131
+ 'Profiling time/resources spent in Garbage Collection force enabled. Do not use Ractors in combination ' \
132
+ 'with this option as profiles will be incomplete.'
133
+ )
134
+ end
135
+
136
+ true
137
+ else
138
+ false
139
+ end
140
+ end
141
+
142
+ def print_new_profiler_warnings
143
+ if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new('2.6')
144
+ Datadog.logger.warn(
145
+ 'New Ruby profiler has been force-enabled. This is a beta feature. Please report any issues ' \
146
+ 'you run into to Datadog support or via <https://github.com/datadog/dd-trace-rb/issues/new>!'
147
+ )
148
+ else
149
+ # For more details on the issue, see the "BIG Issue" comment on `gvl_owner` function in
150
+ # `private_vm_api_access.c`.
151
+ Datadog.logger.warn(
152
+ 'New Ruby profiler has been force-enabled on a legacy Ruby version (< 2.6). This is not recommended in ' \
153
+ 'production environments, as due to limitations in Ruby APIs, we suspect it may lead to crashes in very ' \
154
+ 'rare situations. Please report any issues you run into to Datadog support or ' \
155
+ 'via <https://github.com/datadog/dd-trace-rb/issues/new>!'
156
+ )
157
+ end
158
+ end
159
+ end
160
+ end
161
+ end
@@ -0,0 +1,41 @@
1
+ require 'time'
2
+
3
+ require_relative '../pprof/template'
4
+
5
+ module Datadog
6
+ module Profiling
7
+ module Encoding
8
+ module Profile
9
+ # Encodes gathered data into the pprof format
10
+ module Protobuf
11
+ module_function
12
+
13
+ def encode(event_count:, event_groups:, start:, finish:)
14
+ # Create a pprof template from the list of event types
15
+ event_classes = event_groups.collect(&:event_class).uniq
16
+ template = Pprof::Template.for_event_classes(event_classes)
17
+
18
+ # Add all events to the pprof
19
+ event_groups.each { |event_group| template.add_events!(event_group.event_class, event_group.events) }
20
+
21
+ Datadog.logger.debug do
22
+ max_events = Datadog.configuration.profiling.advanced.max_events
23
+ events_sampled =
24
+ if event_count == max_events
25
+ 'max events limit hit, events were sampled [profile will be biased], '
26
+ else
27
+ ''
28
+ end
29
+
30
+ "Encoding profile covering #{start.iso8601} to #{finish.iso8601}, " \
31
+ "events: #{event_count} (#{events_sampled}#{template.debug_statistics})"
32
+ end
33
+
34
+ # Build the profile and encode it
35
+ template.to_pprof(start: start, finish: finish)
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
41
+ end
@@ -0,0 +1,13 @@
1
+ module Datadog
2
+ module Profiling
3
+ # Describes a sample of some data obtained from the runtime.
4
+ class Event
5
+ attr_reader \
6
+ :timestamp
7
+
8
+ def initialize(timestamp = nil)
9
+ @timestamp = timestamp || Time.now.utc.to_f
10
+ end
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,80 @@
1
+ require_relative '../event'
2
+
3
+ module Datadog
4
+ module Profiling
5
+ module Events
6
+ # Describes a stack profiling event
7
+ class Stack < Event
8
+ attr_reader \
9
+ :hash,
10
+ :frames,
11
+ :total_frame_count,
12
+ :thread_id,
13
+ :root_span_id,
14
+ :span_id,
15
+ :trace_resource
16
+
17
+ def initialize(
18
+ timestamp,
19
+ frames,
20
+ total_frame_count,
21
+ thread_id,
22
+ root_span_id,
23
+ span_id,
24
+ trace_resource
25
+ )
26
+ super(timestamp)
27
+
28
+ @frames = frames
29
+ @total_frame_count = total_frame_count
30
+ @thread_id = thread_id
31
+ @root_span_id = root_span_id
32
+ @span_id = span_id
33
+ @trace_resource = trace_resource
34
+
35
+ @hash = [
36
+ thread_id,
37
+ root_span_id,
38
+ span_id,
39
+ # trace_resource is deliberately not included -- events that share the same (root_span_id, span_id) refer
40
+ # to the same trace
41
+ frames.collect(&:hash),
42
+ total_frame_count
43
+ ].hash
44
+ end
45
+ end
46
+
47
+ # Describes a stack sample
48
+ class StackSample < Stack
49
+ attr_reader \
50
+ :cpu_time_interval_ns,
51
+ :wall_time_interval_ns
52
+
53
+ def initialize(
54
+ timestamp,
55
+ frames,
56
+ total_frame_count,
57
+ thread_id,
58
+ root_span_id,
59
+ span_id,
60
+ trace_resource,
61
+ cpu_time_interval_ns,
62
+ wall_time_interval_ns
63
+ )
64
+ super(
65
+ timestamp,
66
+ frames,
67
+ total_frame_count,
68
+ thread_id,
69
+ root_span_id,
70
+ span_id,
71
+ trace_resource
72
+ )
73
+
74
+ @cpu_time_interval_ns = cpu_time_interval_ns
75
+ @wall_time_interval_ns = wall_time_interval_ns
76
+ end
77
+ end
78
+ end
79
+ end
80
+ end