ddtrace 1.1.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (524) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +129 -1
  3. data/LICENSE-3rdparty.csv +2 -0
  4. data/README.md +8 -3
  5. data/ext/ddtrace_profiling_loader/ddtrace_profiling_loader.c +2 -2
  6. data/ext/ddtrace_profiling_loader/extconf.rb +1 -0
  7. data/ext/ddtrace_profiling_native_extension/NativeExtensionDesign.md +15 -7
  8. data/ext/ddtrace_profiling_native_extension/clock_id.h +21 -1
  9. data/ext/ddtrace_profiling_native_extension/clock_id_from_pthread.c +31 -2
  10. data/ext/ddtrace_profiling_native_extension/clock_id_noop.c +11 -2
  11. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.c +390 -0
  12. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.h +6 -0
  13. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time_worker.c +391 -0
  14. data/ext/ddtrace_profiling_native_extension/collectors_stack.c +23 -19
  15. data/ext/ddtrace_profiling_native_extension/collectors_stack.h +9 -0
  16. data/ext/ddtrace_profiling_native_extension/extconf.rb +64 -16
  17. data/ext/ddtrace_profiling_native_extension/helpers.h +12 -0
  18. data/ext/ddtrace_profiling_native_extension/http_transport.c +334 -0
  19. data/ext/ddtrace_profiling_native_extension/{libddprof_helpers.h → libdatadog_helpers.h} +2 -1
  20. data/ext/ddtrace_profiling_native_extension/native_extension_helpers.rb +116 -12
  21. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.c +89 -4
  22. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.h +5 -5
  23. data/ext/ddtrace_profiling_native_extension/profiling.c +8 -3
  24. data/ext/ddtrace_profiling_native_extension/ruby_helpers.c +25 -0
  25. data/ext/ddtrace_profiling_native_extension/ruby_helpers.h +65 -0
  26. data/ext/ddtrace_profiling_native_extension/stack_recorder.c +311 -28
  27. data/ext/ddtrace_profiling_native_extension/stack_recorder.h +18 -8
  28. data/lib/datadog/appsec/autoload.rb +4 -2
  29. data/lib/datadog/appsec/configuration.rb +1 -1
  30. data/lib/datadog/appsec/contrib/auto_instrument.rb +0 -2
  31. data/lib/datadog/appsec/contrib/configuration/settings.rb +1 -1
  32. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +2 -2
  33. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +6 -6
  34. data/lib/datadog/appsec/contrib/rack/integration.rb +5 -5
  35. data/lib/datadog/appsec/contrib/rack/patcher.rb +2 -2
  36. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +1 -1
  37. data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +1 -1
  38. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +1 -1
  39. data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +2 -2
  40. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +3 -3
  41. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +2 -2
  42. data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +4 -4
  43. data/lib/datadog/appsec/contrib/rails/integration.rb +4 -4
  44. data/lib/datadog/appsec/contrib/rails/patcher.rb +16 -12
  45. data/lib/datadog/appsec/contrib/rails/reactive/action.rb +1 -1
  46. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +2 -2
  47. data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +5 -5
  48. data/lib/datadog/appsec/contrib/sinatra/integration.rb +4 -4
  49. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +16 -12
  50. data/lib/datadog/appsec/event.rb +3 -3
  51. data/lib/datadog/appsec/extensions.rb +1 -1
  52. data/lib/datadog/appsec/processor.rb +1 -1
  53. data/lib/datadog/appsec/reactive/engine.rb +2 -2
  54. data/lib/datadog/appsec/reactive/operation.rb +3 -3
  55. data/lib/datadog/appsec.rb +5 -5
  56. data/lib/datadog/ci/configuration/components.rb +1 -1
  57. data/lib/datadog/ci/configuration/settings.rb +1 -1
  58. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +2 -2
  59. data/lib/datadog/ci/contrib/cucumber/formatter.rb +5 -5
  60. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +1 -1
  61. data/lib/datadog/ci/contrib/cucumber/integration.rb +4 -4
  62. data/lib/datadog/ci/contrib/cucumber/patcher.rb +2 -2
  63. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +2 -2
  64. data/lib/datadog/ci/contrib/rspec/example.rb +5 -5
  65. data/lib/datadog/ci/contrib/rspec/integration.rb +4 -4
  66. data/lib/datadog/ci/contrib/rspec/patcher.rb +2 -2
  67. data/lib/datadog/ci/ext/environment.rb +8 -6
  68. data/lib/datadog/ci/extensions.rb +4 -4
  69. data/lib/datadog/ci/flush.rb +2 -2
  70. data/lib/datadog/ci/test.rb +3 -3
  71. data/lib/datadog/ci.rb +6 -6
  72. data/lib/datadog/core/buffer/cruby.rb +1 -1
  73. data/lib/datadog/core/buffer/thread_safe.rb +1 -1
  74. data/lib/datadog/core/configuration/agent_settings_resolver.rb +6 -6
  75. data/lib/datadog/core/configuration/base.rb +11 -2
  76. data/lib/datadog/core/configuration/components.rb +70 -52
  77. data/lib/datadog/core/configuration/option_definition.rb +1 -1
  78. data/lib/datadog/core/configuration/option_definition_set.rb +1 -1
  79. data/lib/datadog/core/configuration/options.rb +3 -3
  80. data/lib/datadog/core/configuration/settings.rb +42 -8
  81. data/lib/datadog/core/configuration.rb +8 -5
  82. data/lib/datadog/core/diagnostics/environment_logger.rb +1 -1
  83. data/lib/datadog/core/diagnostics/health.rb +2 -2
  84. data/lib/datadog/core/environment/cgroup.rb +1 -1
  85. data/lib/datadog/core/environment/container.rb +1 -1
  86. data/lib/datadog/core/environment/ext.rb +1 -1
  87. data/lib/datadog/core/environment/identity.rb +2 -2
  88. data/lib/datadog/core/environment/platform.rb +40 -0
  89. data/lib/datadog/core/environment/socket.rb +1 -1
  90. data/lib/datadog/core/error.rb +1 -1
  91. data/lib/datadog/core/extensions.rb +1 -1
  92. data/lib/datadog/core/metrics/client.rb +8 -8
  93. data/lib/datadog/core/metrics/options.rb +3 -3
  94. data/lib/datadog/core/runtime/metrics.rb +6 -6
  95. data/lib/datadog/core/telemetry/client.rb +79 -0
  96. data/lib/datadog/core/telemetry/collector.rb +234 -0
  97. data/lib/datadog/core/telemetry/emitter.rb +48 -0
  98. data/lib/datadog/core/telemetry/event.rb +71 -0
  99. data/lib/datadog/core/telemetry/ext.rb +11 -0
  100. data/lib/datadog/core/telemetry/heartbeat.rb +37 -0
  101. data/lib/datadog/core/telemetry/http/adapters/net.rb +113 -0
  102. data/lib/datadog/core/telemetry/http/env.rb +20 -0
  103. data/lib/datadog/core/telemetry/http/ext.rb +20 -0
  104. data/lib/datadog/core/telemetry/http/response.rb +68 -0
  105. data/lib/datadog/core/telemetry/http/transport.rb +53 -0
  106. data/lib/datadog/core/telemetry/v1/app_event.rb +52 -0
  107. data/lib/datadog/core/telemetry/v1/application.rb +86 -0
  108. data/lib/datadog/core/telemetry/v1/configuration.rb +25 -0
  109. data/lib/datadog/core/telemetry/v1/dependency.rb +36 -0
  110. data/lib/datadog/core/telemetry/v1/host.rb +51 -0
  111. data/lib/datadog/core/telemetry/v1/integration.rb +58 -0
  112. data/lib/datadog/core/telemetry/v1/product.rb +28 -0
  113. data/lib/datadog/core/telemetry/v1/telemetry_request.rb +100 -0
  114. data/lib/datadog/core/utils/object_set.rb +1 -1
  115. data/lib/datadog/core/utils/sequence.rb +5 -0
  116. data/lib/datadog/core/utils/string_table.rb +1 -1
  117. data/lib/datadog/core/utils/time.rb +3 -3
  118. data/lib/datadog/core/utils.rb +3 -3
  119. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +2 -2
  120. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +3 -3
  121. data/lib/datadog/core/workers/async.rb +1 -1
  122. data/lib/datadog/core/workers/polling.rb +2 -2
  123. data/lib/datadog/core/workers/runtime_metrics.rb +4 -4
  124. data/lib/datadog/core.rb +50 -50
  125. data/lib/datadog/kit.rb +1 -1
  126. data/lib/datadog/opentracer/distributed_headers.rb +2 -2
  127. data/lib/datadog/opentracer/rack_propagator.rb +11 -7
  128. data/lib/datadog/opentracer/span.rb +1 -1
  129. data/lib/datadog/opentracer/text_map_propagator.rb +9 -6
  130. data/lib/datadog/opentracer/thread_local_scope_manager.rb +26 -3
  131. data/lib/datadog/opentracer/tracer.rb +19 -15
  132. data/lib/datadog/opentracer.rb +16 -16
  133. data/lib/datadog/profiling/buffer.rb +3 -3
  134. data/lib/datadog/profiling/collectors/code_provenance.rb +1 -0
  135. data/lib/datadog/profiling/collectors/cpu_and_wall_time.rb +27 -0
  136. data/lib/datadog/profiling/collectors/cpu_and_wall_time_worker.rb +74 -0
  137. data/lib/datadog/profiling/collectors/old_stack.rb +7 -7
  138. data/lib/datadog/profiling/collectors/stack.rb +3 -6
  139. data/lib/datadog/profiling/encoding/profile.rb +8 -12
  140. data/lib/datadog/profiling/events/stack.rb +1 -1
  141. data/lib/datadog/profiling/exporter.rb +66 -9
  142. data/lib/datadog/profiling/ext/forking.rb +41 -42
  143. data/lib/datadog/profiling/ext.rb +3 -15
  144. data/lib/datadog/profiling/flush.rb +25 -56
  145. data/lib/datadog/profiling/http_transport.rb +132 -0
  146. data/lib/datadog/profiling/old_ext.rb +42 -0
  147. data/lib/datadog/profiling/old_recorder.rb +101 -0
  148. data/lib/datadog/profiling/pprof/builder.rb +4 -4
  149. data/lib/datadog/profiling/pprof/converter.rb +1 -1
  150. data/lib/datadog/profiling/pprof/message_set.rb +1 -1
  151. data/lib/datadog/profiling/pprof/stack_sample.rb +4 -4
  152. data/lib/datadog/profiling/pprof/string_table.rb +1 -1
  153. data/lib/datadog/profiling/pprof/template.rb +5 -5
  154. data/lib/datadog/profiling/preload.rb +1 -1
  155. data/lib/datadog/profiling/scheduler.rb +28 -46
  156. data/lib/datadog/profiling/stack_recorder.rb +14 -4
  157. data/lib/datadog/profiling/tag_builder.rb +6 -1
  158. data/lib/datadog/profiling/tasks/setup.rb +2 -2
  159. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +2 -2
  160. data/lib/datadog/profiling/trace_identifiers/helper.rb +1 -1
  161. data/lib/datadog/profiling/transport/http/api/endpoint.rb +13 -35
  162. data/lib/datadog/profiling/transport/http/api/instance.rb +2 -2
  163. data/lib/datadog/profiling/transport/http/api/spec.rb +1 -1
  164. data/lib/datadog/profiling/transport/http/api.rb +5 -5
  165. data/lib/datadog/profiling/transport/http/builder.rb +3 -3
  166. data/lib/datadog/profiling/transport/http/client.rb +6 -4
  167. data/lib/datadog/profiling/transport/http/response.rb +1 -3
  168. data/lib/datadog/profiling/transport/http.rb +22 -16
  169. data/lib/datadog/profiling.rb +21 -20
  170. data/lib/datadog/tracing/analytics.rb +1 -1
  171. data/lib/datadog/tracing/buffer.rb +5 -5
  172. data/lib/datadog/tracing/context.rb +1 -1
  173. data/lib/datadog/tracing/context_provider.rb +18 -2
  174. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +2 -2
  175. data/lib/datadog/tracing/contrib/action_cable/event.rb +4 -5
  176. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +4 -4
  177. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +3 -3
  178. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +4 -4
  179. data/lib/datadog/tracing/contrib/action_cable/events.rb +4 -4
  180. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +3 -4
  181. data/lib/datadog/tracing/contrib/action_cable/integration.rb +4 -4
  182. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +4 -4
  183. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +2 -2
  184. data/lib/datadog/tracing/contrib/action_mailer/event.rb +3 -3
  185. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +3 -3
  186. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +3 -3
  187. data/lib/datadog/tracing/contrib/action_mailer/events.rb +2 -2
  188. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +4 -4
  189. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +3 -3
  190. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +10 -6
  191. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +2 -2
  192. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +2 -2
  193. data/lib/datadog/tracing/contrib/action_pack/integration.rb +4 -4
  194. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +2 -2
  195. data/lib/datadog/tracing/contrib/action_pack/utils.rb +1 -1
  196. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +2 -2
  197. data/lib/datadog/tracing/contrib/action_view/event.rb +1 -1
  198. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +5 -5
  199. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +5 -5
  200. data/lib/datadog/tracing/contrib/action_view/events.rb +2 -2
  201. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +2 -2
  202. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +2 -2
  203. data/lib/datadog/tracing/contrib/action_view/integration.rb +4 -4
  204. data/lib/datadog/tracing/contrib/action_view/patcher.rb +7 -7
  205. data/lib/datadog/tracing/contrib/action_view/utils.rb +1 -1
  206. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +3 -3
  207. data/lib/datadog/tracing/contrib/active_job/event.rb +3 -3
  208. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +4 -4
  209. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +4 -4
  210. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +4 -4
  211. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +4 -4
  212. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +4 -4
  213. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +4 -4
  214. data/lib/datadog/tracing/contrib/active_job/events.rb +6 -6
  215. data/lib/datadog/tracing/contrib/active_job/integration.rb +4 -4
  216. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +0 -2
  217. data/lib/datadog/tracing/contrib/active_job/patcher.rb +4 -4
  218. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +2 -2
  219. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +4 -5
  220. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +3 -3
  221. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +2 -2
  222. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +2 -2
  223. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +3 -3
  224. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +3 -4
  225. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +2 -2
  226. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +3 -3
  227. data/lib/datadog/tracing/contrib/active_record/event.rb +1 -1
  228. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +4 -4
  229. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +6 -6
  230. data/lib/datadog/tracing/contrib/active_record/events.rb +2 -2
  231. data/lib/datadog/tracing/contrib/active_record/integration.rb +6 -6
  232. data/lib/datadog/tracing/contrib/active_record/patcher.rb +2 -2
  233. data/lib/datadog/tracing/contrib/active_record/utils.rb +2 -2
  234. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +19 -9
  235. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +2 -2
  236. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +1 -1
  237. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +2 -2
  238. data/lib/datadog/tracing/contrib/active_support/integration.rb +5 -5
  239. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +1 -1
  240. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +1 -1
  241. data/lib/datadog/tracing/contrib/active_support/patcher.rb +2 -2
  242. data/lib/datadog/tracing/contrib/analytics.rb +1 -1
  243. data/lib/datadog/tracing/contrib/auto_instrument.rb +4 -4
  244. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +2 -2
  245. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +3 -4
  246. data/lib/datadog/tracing/contrib/aws/integration.rb +3 -3
  247. data/lib/datadog/tracing/contrib/aws/patcher.rb +5 -5
  248. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +2 -2
  249. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +1 -1
  250. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +3 -3
  251. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +2 -2
  252. data/lib/datadog/tracing/contrib/configurable.rb +2 -2
  253. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +1 -1
  254. data/lib/datadog/tracing/contrib/configuration/settings.rb +2 -2
  255. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +2 -2
  256. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +4 -5
  257. data/lib/datadog/tracing/contrib/dalli/integration.rb +3 -3
  258. data/lib/datadog/tracing/contrib/dalli/patcher.rb +3 -3
  259. data/lib/datadog/tracing/contrib/dalli/quantize.rb +1 -1
  260. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +3 -3
  261. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +2 -0
  262. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +3 -3
  263. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +8 -2
  264. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +3 -4
  265. data/lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb +32 -0
  266. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +2 -2
  267. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +3 -3
  268. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +6 -7
  269. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +1 -1
  270. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +2 -2
  271. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +4 -5
  272. data/lib/datadog/tracing/contrib/ethon/integration.rb +4 -4
  273. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +3 -4
  274. data/lib/datadog/tracing/contrib/ethon/patcher.rb +3 -3
  275. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +2 -2
  276. data/lib/datadog/tracing/contrib/excon/integration.rb +4 -4
  277. data/lib/datadog/tracing/contrib/excon/middleware.rb +6 -7
  278. data/lib/datadog/tracing/contrib/excon/patcher.rb +2 -2
  279. data/lib/datadog/tracing/contrib/extensions.rb +5 -3
  280. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +2 -2
  281. data/lib/datadog/tracing/contrib/faraday/integration.rb +4 -4
  282. data/lib/datadog/tracing/contrib/faraday/middleware.rb +5 -6
  283. data/lib/datadog/tracing/contrib/faraday/patcher.rb +5 -5
  284. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +3 -3
  285. data/lib/datadog/tracing/contrib/grape/endpoint.rb +4 -5
  286. data/lib/datadog/tracing/contrib/grape/integration.rb +3 -3
  287. data/lib/datadog/tracing/contrib/grape/patcher.rb +4 -4
  288. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +2 -2
  289. data/lib/datadog/tracing/contrib/graphql/integration.rb +3 -3
  290. data/lib/datadog/tracing/contrib/graphql/patcher.rb +2 -3
  291. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +4 -3
  292. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +14 -5
  293. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +6 -6
  294. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +7 -4
  295. data/lib/datadog/tracing/contrib/grpc/ext.rb +1 -0
  296. data/lib/datadog/tracing/contrib/grpc/integration.rb +3 -3
  297. data/lib/datadog/tracing/contrib/grpc/patcher.rb +5 -5
  298. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +1 -2
  299. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +2 -2
  300. data/lib/datadog/tracing/contrib/http/instrumentation.rb +3 -4
  301. data/lib/datadog/tracing/contrib/http/integration.rb +6 -6
  302. data/lib/datadog/tracing/contrib/http/patcher.rb +3 -3
  303. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +2 -2
  304. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +4 -5
  305. data/lib/datadog/tracing/contrib/httpclient/integration.rb +4 -4
  306. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +3 -3
  307. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +2 -2
  308. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +4 -5
  309. data/lib/datadog/tracing/contrib/httprb/integration.rb +4 -4
  310. data/lib/datadog/tracing/contrib/httprb/patcher.rb +3 -3
  311. data/lib/datadog/tracing/contrib/integration.rb +3 -3
  312. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +2 -2
  313. data/lib/datadog/tracing/contrib/kafka/event.rb +3 -3
  314. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +2 -2
  315. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +3 -3
  316. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +3 -3
  317. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +4 -4
  318. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +4 -4
  319. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +4 -4
  320. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +4 -4
  321. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +2 -2
  322. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +2 -2
  323. data/lib/datadog/tracing/contrib/kafka/events.rb +9 -9
  324. data/lib/datadog/tracing/contrib/kafka/integration.rb +3 -3
  325. data/lib/datadog/tracing/contrib/kafka/patcher.rb +3 -3
  326. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +2 -2
  327. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +1 -2
  328. data/lib/datadog/tracing/contrib/lograge/integration.rb +3 -3
  329. data/lib/datadog/tracing/contrib/lograge/patcher.rb +2 -2
  330. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +2 -2
  331. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +3 -3
  332. data/lib/datadog/tracing/contrib/mongodb/integration.rb +4 -4
  333. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +1 -1
  334. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +3 -3
  335. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +4 -4
  336. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +2 -2
  337. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +3 -4
  338. data/lib/datadog/tracing/contrib/mysql2/integration.rb +3 -3
  339. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +2 -2
  340. data/lib/datadog/tracing/contrib/patcher.rb +13 -2
  341. data/lib/datadog/tracing/contrib/pg/configuration/settings.rb +35 -0
  342. data/lib/datadog/tracing/contrib/pg/ext.rb +31 -0
  343. data/lib/datadog/tracing/contrib/pg/instrumentation.rb +128 -0
  344. data/lib/datadog/tracing/contrib/pg/integration.rb +43 -0
  345. data/lib/datadog/tracing/contrib/pg/patcher.rb +31 -0
  346. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +2 -2
  347. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +2 -3
  348. data/lib/datadog/tracing/contrib/presto/integration.rb +3 -3
  349. data/lib/datadog/tracing/contrib/presto/patcher.rb +4 -4
  350. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +2 -2
  351. data/lib/datadog/tracing/contrib/qless/integration.rb +3 -3
  352. data/lib/datadog/tracing/contrib/qless/patcher.rb +1 -2
  353. data/lib/datadog/tracing/contrib/qless/qless_job.rb +2 -3
  354. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +0 -2
  355. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +3 -3
  356. data/lib/datadog/tracing/contrib/que/integration.rb +4 -4
  357. data/lib/datadog/tracing/contrib/que/patcher.rb +1 -1
  358. data/lib/datadog/tracing/contrib/que/tracer.rb +1 -1
  359. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +2 -2
  360. data/lib/datadog/tracing/contrib/racecar/event.rb +4 -5
  361. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +2 -2
  362. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +2 -2
  363. data/lib/datadog/tracing/contrib/racecar/events/message.rb +2 -2
  364. data/lib/datadog/tracing/contrib/racecar/events.rb +3 -3
  365. data/lib/datadog/tracing/contrib/racecar/integration.rb +3 -3
  366. data/lib/datadog/tracing/contrib/racecar/patcher.rb +3 -3
  367. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +2 -2
  368. data/lib/datadog/tracing/contrib/rack/integration.rb +4 -4
  369. data/lib/datadog/tracing/contrib/rack/middlewares.rb +24 -20
  370. data/lib/datadog/tracing/contrib/rack/patcher.rb +12 -2
  371. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +1 -1
  372. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +4 -1
  373. data/lib/datadog/tracing/contrib/rails/framework.rb +18 -22
  374. data/lib/datadog/tracing/contrib/rails/integration.rb +4 -4
  375. data/lib/datadog/tracing/contrib/rails/log_injection.rb +0 -2
  376. data/lib/datadog/tracing/contrib/rails/middlewares.rb +1 -2
  377. data/lib/datadog/tracing/contrib/rails/patcher.rb +7 -8
  378. data/lib/datadog/tracing/contrib/rails/railtie.rb +3 -3
  379. data/lib/datadog/tracing/contrib/rails/utils.rb +1 -1
  380. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +17 -2
  381. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +12 -7
  382. data/lib/datadog/tracing/contrib/rake/integration.rb +3 -3
  383. data/lib/datadog/tracing/contrib/rake/patcher.rb +3 -4
  384. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +1 -1
  385. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +2 -2
  386. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +6 -7
  387. data/lib/datadog/tracing/contrib/redis/integration.rb +3 -3
  388. data/lib/datadog/tracing/contrib/redis/patcher.rb +6 -6
  389. data/lib/datadog/tracing/contrib/redis/tags.rb +3 -4
  390. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +3 -3
  391. data/lib/datadog/tracing/contrib/resque/integration.rb +3 -3
  392. data/lib/datadog/tracing/contrib/resque/patcher.rb +2 -2
  393. data/lib/datadog/tracing/contrib/resque/resque_job.rb +3 -4
  394. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +3 -2
  395. data/lib/datadog/tracing/contrib/rest_client/integration.rb +3 -3
  396. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +2 -2
  397. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +5 -6
  398. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +2 -2
  399. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +1 -2
  400. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +3 -3
  401. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +2 -2
  402. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +2 -2
  403. data/lib/datadog/tracing/contrib/sequel/database.rb +4 -5
  404. data/lib/datadog/tracing/contrib/sequel/dataset.rb +4 -5
  405. data/lib/datadog/tracing/contrib/sequel/integration.rb +3 -3
  406. data/lib/datadog/tracing/contrib/sequel/patcher.rb +3 -3
  407. data/lib/datadog/tracing/contrib/sequel/utils.rb +2 -2
  408. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +3 -3
  409. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +4 -4
  410. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +1 -1
  411. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +1 -1
  412. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +4 -5
  413. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +3 -3
  414. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +6 -0
  415. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +3 -3
  416. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +14 -7
  417. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +19 -1
  418. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/{scheduled_push.rb → redis_info.rb} +5 -6
  419. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_poller.rb +53 -0
  420. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +5 -6
  421. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +2 -2
  422. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +2 -2
  423. data/lib/datadog/tracing/contrib/sinatra/env.rb +2 -2
  424. data/lib/datadog/tracing/contrib/sinatra/framework.rb +0 -2
  425. data/lib/datadog/tracing/contrib/sinatra/headers.rb +1 -1
  426. data/lib/datadog/tracing/contrib/sinatra/integration.rb +3 -3
  427. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +5 -5
  428. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +7 -8
  429. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +6 -7
  430. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +2 -2
  431. data/lib/datadog/tracing/contrib/sneakers/integration.rb +4 -4
  432. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +2 -2
  433. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +2 -3
  434. data/lib/datadog/tracing/contrib/status_code_matcher.rb +2 -2
  435. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +2 -2
  436. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +3 -4
  437. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +3 -3
  438. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +4 -5
  439. data/lib/datadog/tracing/contrib.rb +48 -47
  440. data/lib/datadog/tracing/correlation.rb +1 -1
  441. data/lib/datadog/tracing/distributed/headers/b3.rb +4 -4
  442. data/lib/datadog/tracing/distributed/headers/b3_single.rb +7 -7
  443. data/lib/datadog/tracing/distributed/headers/datadog.rb +3 -3
  444. data/lib/datadog/tracing/distributed/headers/parser.rb +37 -0
  445. data/lib/datadog/tracing/distributed/helpers.rb +36 -2
  446. data/lib/datadog/tracing/distributed/metadata/b3.rb +55 -0
  447. data/lib/datadog/tracing/distributed/metadata/b3_single.rb +66 -0
  448. data/lib/datadog/tracing/distributed/metadata/datadog.rb +73 -0
  449. data/lib/datadog/tracing/distributed/metadata/parser.rb +34 -0
  450. data/lib/datadog/tracing/event.rb +1 -1
  451. data/lib/datadog/tracing/metadata/analytics.rb +2 -2
  452. data/lib/datadog/tracing/metadata/errors.rb +2 -2
  453. data/lib/datadog/tracing/metadata/ext.rb +25 -0
  454. data/lib/datadog/tracing/metadata/tagging.rb +8 -2
  455. data/lib/datadog/tracing/metadata.rb +3 -3
  456. data/lib/datadog/tracing/pipeline/span_filter.rb +10 -6
  457. data/lib/datadog/tracing/pipeline.rb +3 -3
  458. data/lib/datadog/tracing/propagation/grpc.rb +68 -58
  459. data/lib/datadog/tracing/propagation/http.rb +8 -8
  460. data/lib/datadog/tracing/runtime/metrics.rb +1 -1
  461. data/lib/datadog/tracing/sampling/all_sampler.rb +1 -1
  462. data/lib/datadog/tracing/sampling/priority_sampler.rb +5 -5
  463. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +2 -2
  464. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +3 -3
  465. data/lib/datadog/tracing/sampling/rate_limiter.rb +1 -1
  466. data/lib/datadog/tracing/sampling/rate_sampler.rb +7 -7
  467. data/lib/datadog/tracing/sampling/rule.rb +3 -3
  468. data/lib/datadog/tracing/sampling/rule_sampler.rb +4 -4
  469. data/lib/datadog/tracing/sampling/span/matcher.rb +80 -0
  470. data/lib/datadog/tracing/span.rb +25 -5
  471. data/lib/datadog/tracing/span_operation.rb +10 -9
  472. data/lib/datadog/tracing/sync_writer.rb +5 -5
  473. data/lib/datadog/tracing/trace_operation.rb +16 -9
  474. data/lib/datadog/tracing/trace_segment.rb +5 -5
  475. data/lib/datadog/tracing/tracer.rb +15 -15
  476. data/lib/datadog/tracing/workers/trace_writer.rb +9 -9
  477. data/lib/datadog/tracing/workers.rb +3 -3
  478. data/lib/datadog/tracing/writer.rb +5 -5
  479. data/lib/datadog/tracing.rb +8 -8
  480. data/lib/ddtrace/auto_instrument.rb +9 -2
  481. data/lib/ddtrace/transport/ext.rb +7 -1
  482. data/lib/ddtrace/transport/http/adapters/net.rb +3 -2
  483. data/lib/ddtrace/transport/http/adapters/test.rb +1 -1
  484. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +2 -2
  485. data/lib/ddtrace/transport/http/api/map.rb +1 -1
  486. data/lib/ddtrace/transport/http/api.rb +4 -4
  487. data/lib/ddtrace/transport/http/builder.rb +5 -5
  488. data/lib/ddtrace/transport/http/client.rb +2 -2
  489. data/lib/ddtrace/transport/http/response.rb +1 -1
  490. data/lib/ddtrace/transport/http/statistics.rb +1 -1
  491. data/lib/ddtrace/transport/http/traces.rb +5 -5
  492. data/lib/ddtrace/transport/http.rb +12 -9
  493. data/lib/ddtrace/transport/io/client.rb +2 -2
  494. data/lib/ddtrace/transport/io/response.rb +1 -1
  495. data/lib/ddtrace/transport/io/traces.rb +3 -3
  496. data/lib/ddtrace/transport/io.rb +3 -3
  497. data/lib/ddtrace/transport/statistics.rb +2 -2
  498. data/lib/ddtrace/transport/trace_formatter.rb +5 -5
  499. data/lib/ddtrace/transport/traces.rb +5 -5
  500. data/lib/ddtrace/version.rb +1 -1
  501. data/lib/ddtrace.rb +6 -6
  502. metadata +57 -33
  503. data/.editorconfig +0 -22
  504. data/.gitignore +0 -58
  505. data/CONTRIBUTING.md +0 -81
  506. data/ddtrace.gemspec +0 -68
  507. data/docs/0.x-trace.png +0 -0
  508. data/docs/1.0-trace.png +0 -0
  509. data/docs/AutoInstrumentation.md +0 -36
  510. data/docs/Deprecation.md +0 -8
  511. data/docs/DevelopmentGuide.md +0 -259
  512. data/docs/GettingStarted.md +0 -2688
  513. data/docs/ProfilingDevelopment.md +0 -110
  514. data/docs/PublicApi.md +0 -14
  515. data/docs/UpgradeGuide.md +0 -736
  516. data/lib/datadog/profiling/recorder.rb +0 -117
  517. data/lib/datadog/profiling/transport/client.rb +0 -16
  518. data/lib/datadog/profiling/transport/io/client.rb +0 -29
  519. data/lib/datadog/profiling/transport/io/response.rb +0 -18
  520. data/lib/datadog/profiling/transport/io.rb +0 -32
  521. data/lib/datadog/profiling/transport/parcel.rb +0 -19
  522. data/lib/datadog/profiling/transport/request.rb +0 -17
  523. data/lib/datadog/profiling/transport/response.rb +0 -10
  524. data/lib/datadog/tracing/distributed/parser.rb +0 -70
data/lib/datadog/core.rb CHANGED
@@ -4,57 +4,57 @@
4
4
  # Would be better to lazy load these; not
5
5
  # all of these components will be used in
6
6
  # every application.
7
- # require 'datadog/core/buffer/cruby'
8
- # require 'datadog/core/buffer/random'
9
- # require 'datadog/core/buffer/thread_safe'
10
- # require 'datadog/core/chunker'
11
- # require 'datadog/core/configuration'
12
- # require 'datadog/core/diagnostics/environment_logger'
13
- # require 'datadog/core/diagnostics/ext'
14
- # require 'datadog/core/diagnostics/health'
15
- # require 'datadog/core/encoding'
16
- # require 'datadog/core/environment/cgroup'
17
- # require 'datadog/core/environment/class_count'
18
- # require 'datadog/core/environment/container'
19
- # require 'datadog/core/environment/ext'
20
- # require 'datadog/core/environment/gc'
21
- # require 'datadog/core/environment/identity'
22
- # require 'datadog/core/environment/socket'
23
- # require 'datadog/core/environment/thread_count'
24
- # require 'datadog/core/environment/variable_helpers'
25
- # require 'datadog/core/environment/vm_cache'
26
- # require 'datadog/core/error'
27
- # require 'datadog/core/event'
28
- # require 'datadog/core/git/ext'
29
- # require 'datadog/core/logger'
30
- # require 'datadog/core/metrics/client'
31
- # require 'datadog/core/metrics/ext'
32
- # require 'datadog/core/metrics/helpers'
33
- # require 'datadog/core/metrics/logging'
34
- # require 'datadog/core/metrics/metric'
35
- # require 'datadog/core/metrics/options'
36
- # require 'datadog/core/pin'
37
- # require 'datadog/core/quantization/hash'
38
- # require 'datadog/core/quantization/http'
39
- # require 'datadog/core/runtime/ext'
40
- # require 'datadog/core/runtime/metrics'
41
- # require 'datadog/core/utils'
42
- # require 'datadog/core/utils/compression'
43
- # require 'datadog/core/utils/database'
44
- # require 'datadog/core/utils/forking'
45
- # require 'datadog/core/utils/object_set'
46
- # require 'datadog/core/utils/only_once'
47
- # require 'datadog/core/utils/sequence'
48
- # require 'datadog/core/utils/string_table'
49
- # require 'datadog/core/utils/time'
50
- # require 'datadog/core/worker'
51
- # require 'datadog/core/workers/async'
52
- # require 'datadog/core/workers/interval_loop'
53
- # require 'datadog/core/workers/polling'
54
- # require 'datadog/core/workers/queue'
55
- # require 'datadog/core/workers/runtime_metrics'
7
+ # require_relative 'core/buffer/cruby'
8
+ # require_relative 'core/buffer/random'
9
+ # require_relative 'core/buffer/thread_safe'
10
+ # require_relative 'core/chunker'
11
+ # require_relative 'core/configuration'
12
+ # require_relative 'core/diagnostics/environment_logger'
13
+ # require_relative 'core/diagnostics/ext'
14
+ # require_relative 'core/diagnostics/health'
15
+ # require_relative 'core/encoding'
16
+ # require_relative 'core/environment/cgroup'
17
+ # require_relative 'core/environment/class_count'
18
+ # require_relative 'core/environment/container'
19
+ # require_relative 'core/environment/ext'
20
+ # require_relative 'core/environment/gc'
21
+ # require_relative 'core/environment/identity'
22
+ # require_relative 'core/environment/socket'
23
+ # require_relative 'core/environment/thread_count'
24
+ # require_relative 'core/environment/variable_helpers'
25
+ # require_relative 'core/environment/vm_cache'
26
+ # require_relative 'core/error'
27
+ # require_relative 'core/event'
28
+ # require_relative 'core/git/ext'
29
+ # require_relative 'core/logger'
30
+ # require_relative 'core/metrics/client'
31
+ # require_relative 'core/metrics/ext'
32
+ # require_relative 'core/metrics/helpers'
33
+ # require_relative 'core/metrics/logging'
34
+ # require_relative 'core/metrics/metric'
35
+ # require_relative 'core/metrics/options'
36
+ # require_relative 'core/pin'
37
+ # require_relative 'core/quantization/hash'
38
+ # require_relative 'core/quantization/http'
39
+ # require_relative 'core/runtime/ext'
40
+ # require_relative 'core/runtime/metrics'
41
+ # require_relative 'core/utils'
42
+ # require_relative 'core/utils/compression'
43
+ # require_relative 'core/utils/database'
44
+ # require_relative 'core/utils/forking'
45
+ # require_relative 'core/utils/object_set'
46
+ # require_relative 'core/utils/only_once'
47
+ # require_relative 'core/utils/sequence'
48
+ # require_relative 'core/utils/string_table'
49
+ # require_relative 'core/utils/time'
50
+ # require_relative 'core/worker'
51
+ # require_relative 'core/workers/async'
52
+ # require_relative 'core/workers/interval_loop'
53
+ # require_relative 'core/workers/polling'
54
+ # require_relative 'core/workers/queue'
55
+ # require_relative 'core/workers/runtime_metrics'
56
56
 
57
- require 'datadog/core/extensions'
57
+ require_relative 'core/extensions'
58
58
 
59
59
  # We must load core extensions to make certain global APIs
60
60
  # accessible: both for Datadog features and the core itself.
data/lib/datadog/kit.rb CHANGED
@@ -8,4 +8,4 @@ module Datadog
8
8
  end
9
9
  end
10
10
 
11
- require 'datadog/kit/identity'
11
+ require_relative 'kit/identity'
@@ -1,7 +1,7 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/tracing/span'
4
- require 'datadog/tracing/distributed/headers/ext'
3
+ require_relative '../tracing/span'
4
+ require_relative '../tracing/distributed/headers/ext'
5
5
 
6
6
  module Datadog
7
7
  module OpenTracer
@@ -1,10 +1,10 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/tracing/context'
4
- require 'datadog/tracing/distributed/headers/ext'
5
- require 'datadog/tracing/propagation/http'
6
- require 'datadog/tracing/trace_operation'
7
- require 'datadog/opentracer/propagator'
3
+ require_relative '../tracing/context'
4
+ require_relative '../tracing/distributed/headers/ext'
5
+ require_relative '../tracing/propagation/http'
6
+ require_relative '../tracing/trace_operation'
7
+ require_relative 'propagator'
8
8
 
9
9
  module Datadog
10
10
  module OpenTracer
@@ -23,10 +23,14 @@ module Datadog
23
23
  # @param span_context [SpanContext]
24
24
  # @param carrier [Carrier] A carrier object of Rack type
25
25
  def inject(span_context, carrier)
26
- active_trace = span_context.datadog_context.active_trace
26
+ digest = if span_context.datadog_context && span_context.datadog_context.active_trace
27
+ span_context.datadog_context.active_trace.to_digest
28
+ else
29
+ span_context.datadog_trace_digest
30
+ end
27
31
 
28
32
  # Inject Datadog trace properties
29
- Tracing::Propagation::HTTP.inject!(active_trace, carrier)
33
+ Tracing::Propagation::HTTP.inject!(digest, carrier)
30
34
 
31
35
  # Inject baggage
32
36
  span_context.baggage.each do |key, value|
@@ -2,7 +2,7 @@
2
2
 
3
3
  require 'time'
4
4
 
5
- require 'datadog/tracing/metadata/ext'
5
+ require_relative '../tracing/metadata/ext'
6
6
 
7
7
  module Datadog
8
8
  module OpenTracer
@@ -1,9 +1,9 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/tracing/context'
4
- require 'datadog/tracing/distributed/headers/ext'
5
- require 'datadog/tracing/trace_operation'
6
- require 'datadog/opentracer/propagator'
3
+ require_relative '../tracing/context'
4
+ require_relative '../tracing/distributed/headers/ext'
5
+ require_relative '../tracing/trace_operation'
6
+ require_relative 'propagator'
7
7
 
8
8
  module Datadog
9
9
  module OpenTracer
@@ -27,8 +27,11 @@ module Datadog
27
27
  end
28
28
 
29
29
  # Inject Datadog trace properties
30
- active_trace = span_context.datadog_context.active_trace
31
- digest = active_trace.to_digest if active_trace
30
+ digest = if span_context.datadog_context && span_context.datadog_context.active_trace
31
+ span_context.datadog_context.active_trace.to_digest
32
+ else
33
+ span_context.datadog_trace_digest
34
+ end
32
35
  return unless digest
33
36
 
34
37
  carrier[HTTP_HEADER_ORIGIN] = digest.trace_origin
@@ -1,10 +1,19 @@
1
- # typed: true
1
+ # typed: false
2
+
3
+ require_relative '../core/utils/sequence'
2
4
 
3
5
  module Datadog
4
6
  module OpenTracer
5
7
  # OpenTracing adapter for thread local scope management
6
8
  # @public_api
7
9
  class ThreadLocalScopeManager < ScopeManager
10
+ def initialize(*args, &block)
11
+ super(*args, &block)
12
+ @thread_key = "dd_opentracer_context_#{ThreadLocalScopeManager.next_instance_id}".to_sym
13
+ end
14
+
15
+ ruby2_keywords :initialize if respond_to?(:ruby2_keywords, true)
16
+
8
17
  # Make a span instance active.
9
18
  #
10
19
  # @param span [Span] the Span that should become active
@@ -30,13 +39,27 @@ module Datadog
30
39
  # (as Reference#CHILD_OF) of any newly-created Span at Tracer#start_active_span
31
40
  # or Tracer#start_span time.
32
41
  def active
33
- Thread.current[object_id.to_s]
42
+ Thread.current[@thread_key]
43
+ end
44
+
45
+ # Ensure two instances of {FiberLocalContext} do not conflict.
46
+ # We previously used {FiberLocalContext#object_id} to ensure uniqueness
47
+ # but the VM is allowed to reuse `object_id`, allow for the possibility that
48
+ # a new FiberLocalContext would be able to read an old FiberLocalContext's
49
+ # value.
50
+ UNIQUE_INSTANCE_MUTEX = Mutex.new
51
+ UNIQUE_INSTANCE_GENERATOR = Datadog::Core::Utils::Sequence.new
52
+
53
+ private_constant :UNIQUE_INSTANCE_MUTEX, :UNIQUE_INSTANCE_GENERATOR
54
+
55
+ def self.next_instance_id
56
+ UNIQUE_INSTANCE_MUTEX.synchronize { UNIQUE_INSTANCE_GENERATOR.next }
34
57
  end
35
58
 
36
59
  private
37
60
 
38
61
  def set_scope(scope)
39
- Thread.current[object_id.to_s] = scope
62
+ Thread.current[@thread_key] = scope
40
63
  end
41
64
  end
42
65
  end
@@ -2,8 +2,8 @@
2
2
 
3
3
  require 'time'
4
4
 
5
- require 'datadog/tracing/context'
6
- require 'datadog/tracing/tracer'
5
+ require_relative '../tracing/context'
6
+ require_relative '../tracing/tracer'
7
7
 
8
8
  module Datadog
9
9
  module OpenTracer
@@ -52,13 +52,15 @@ module Datadog
52
52
  # yield the newly-started Scope. If `finish_on_close` is true then the
53
53
  # Span will be finished automatically after the block is executed.
54
54
  # @return [Scope] The newly-started and activated Scope
55
- def start_active_span(operation_name,
56
- child_of: nil,
57
- references: nil,
58
- start_time: Time.now,
59
- tags: nil,
60
- ignore_active_scope: false,
61
- finish_on_close: true)
55
+ def start_active_span(
56
+ operation_name,
57
+ child_of: nil,
58
+ references: nil,
59
+ start_time: Time.now,
60
+ tags: nil,
61
+ ignore_active_scope: false,
62
+ finish_on_close: true
63
+ )
62
64
 
63
65
  # When meant to automatically determine the parent,
64
66
  # Use the active scope first, otherwise fall back to any
@@ -124,12 +126,14 @@ module Datadog
124
126
  # References#CHILD_OF reference to the ScopeManager#active.
125
127
  # @return [Span] the newly-started Span instance, which has not been
126
128
  # automatically registered via the ScopeManager
127
- def start_span(operation_name,
128
- child_of: nil,
129
- references: nil,
130
- start_time: Time.now,
131
- tags: nil,
132
- ignore_active_scope: false)
129
+ def start_span(
130
+ operation_name,
131
+ child_of: nil,
132
+ references: nil,
133
+ start_time: Time.now,
134
+ tags: nil,
135
+ ignore_active_scope: false
136
+ )
133
137
 
134
138
  # Derive the OpenTracer::SpanContext to inherit from.
135
139
  parent_span_context = inherited_span_context(child_of, ignore_active_scope: ignore_active_scope)
@@ -2,23 +2,23 @@
2
2
 
3
3
  require 'opentracing'
4
4
  require 'opentracing/carrier'
5
- require 'datadog/tracing'
5
+ require_relative 'tracing'
6
6
 
7
- require 'datadog/opentracer/carrier'
8
- require 'datadog/opentracer/tracer'
9
- require 'datadog/opentracer/span'
10
- require 'datadog/opentracer/span_context'
11
- require 'datadog/opentracer/span_context_factory'
12
- require 'datadog/opentracer/scope'
13
- require 'datadog/opentracer/scope_manager'
14
- require 'datadog/opentracer/thread_local_scope'
15
- require 'datadog/opentracer/thread_local_scope_manager'
16
- require 'datadog/opentracer/distributed_headers'
17
- require 'datadog/opentracer/propagator'
18
- require 'datadog/opentracer/text_map_propagator'
19
- require 'datadog/opentracer/binary_propagator'
20
- require 'datadog/opentracer/rack_propagator'
21
- require 'datadog/opentracer/global_tracer'
7
+ require_relative 'opentracer/carrier'
8
+ require_relative 'opentracer/tracer'
9
+ require_relative 'opentracer/span'
10
+ require_relative 'opentracer/span_context'
11
+ require_relative 'opentracer/span_context_factory'
12
+ require_relative 'opentracer/scope'
13
+ require_relative 'opentracer/scope_manager'
14
+ require_relative 'opentracer/thread_local_scope'
15
+ require_relative 'opentracer/thread_local_scope_manager'
16
+ require_relative 'opentracer/distributed_headers'
17
+ require_relative 'opentracer/propagator'
18
+ require_relative 'opentracer/text_map_propagator'
19
+ require_relative 'opentracer/binary_propagator'
20
+ require_relative 'opentracer/rack_propagator'
21
+ require_relative 'opentracer/global_tracer'
22
22
 
23
23
  # Modify the OpenTracing module functions
24
24
  ::OpenTracing.singleton_class.prepend(Datadog::OpenTracer::GlobalTracer)
@@ -1,8 +1,8 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/core/buffer/thread_safe'
4
- require 'datadog/core/utils/object_set'
5
- require 'datadog/core/utils/string_table'
3
+ require_relative '../core/buffer/thread_safe'
4
+ require_relative '../core/utils/object_set'
5
+ require_relative '../core/utils/string_table'
6
6
 
7
7
  module Datadog
8
8
  module Profiling
@@ -14,6 +14,7 @@ module Datadog
14
14
  #
15
15
  # This metadata powers grouping and categorization of stack trace data.
16
16
  #
17
+ # This class acts both as a collector (collecting data) as well as a recorder (records/serializes it)
17
18
  class CodeProvenance
18
19
  def initialize(standard_library_path: RbConfig::CONFIG.fetch('rubylibdir'))
19
20
  @libraries_by_name = {}
@@ -0,0 +1,27 @@
1
+ # typed: false
2
+
3
+ module Datadog
4
+ module Profiling
5
+ module Collectors
6
+ # Used to periodically sample threads, recording elapsed CPU-time and Wall-time between samples.
7
+ # Triggering of this component (e.g. deciding when to take a sample) is implemented in
8
+ # Collectors::CpuAndWallTimeWorker.
9
+ # The stack collection itself is handled using the Datadog::Profiling::Collectors::Stack.
10
+ # Almost all of this class is implemented as native code.
11
+ #
12
+ # Methods prefixed with _native_ are implemented in `collectors_cpu_and_wall_time.c`
13
+ class CpuAndWallTime
14
+ def initialize(recorder:, max_frames:)
15
+ self.class._native_initialize(self, recorder, max_frames)
16
+ end
17
+
18
+ def inspect
19
+ # Compose Ruby's default inspect with our custom inspect for the native parts
20
+ result = super()
21
+ result[-1] = "#{self.class._native_inspect(self)}>"
22
+ result
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,74 @@
1
+ # typed: false
2
+
3
+ module Datadog
4
+ module Profiling
5
+ module Collectors
6
+ # Used to trigger the periodic execution of Collectors::CpuAndWallTime, which implements all of the sampling logic
7
+ # itself; this class only implements the "doing it periodically" part.
8
+ # Almost all of this class is implemented as native code.
9
+ #
10
+ # Methods prefixed with _native_ are implemented in `collectors_cpu_and_wall_time_worker.c`
11
+ class CpuAndWallTimeWorker
12
+ private
13
+
14
+ attr_accessor :failure_exception
15
+
16
+ public
17
+
18
+ def initialize(
19
+ recorder:,
20
+ max_frames:,
21
+ cpu_and_wall_time_collector: CpuAndWallTime.new(recorder: recorder, max_frames: max_frames)
22
+ )
23
+ self.class._native_initialize(self, cpu_and_wall_time_collector)
24
+ @worker_thread = nil
25
+ @failure_exception = nil
26
+ @start_stop_mutex = Mutex.new
27
+ end
28
+
29
+ def start
30
+ @start_stop_mutex.synchronize do
31
+ return if @worker_thread
32
+
33
+ Datadog.logger.debug { "Starting thread for: #{self}" }
34
+ @worker_thread = Thread.new do
35
+ begin
36
+ Thread.current.name = self.class.name unless Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.3')
37
+
38
+ self.class._native_sampling_loop(self)
39
+
40
+ Datadog.logger.debug('CpuAndWallTimeWorker thread stopping cleanly')
41
+ rescue Exception => e # rubocop:disable Lint/RescueException
42
+ @failure_exception = e
43
+ Datadog.logger.warn(
44
+ "Worker thread error. Cause: #{e.class.name} #{e.message} Location: #{Array(e.backtrace).first}"
45
+ )
46
+ end
47
+ end
48
+ end
49
+
50
+ true
51
+ end
52
+
53
+ # TODO: Provided only for compatibility with the API for Collectors::OldStack used in the Profiler class.
54
+ # Can be removed once we remove OldStack.
55
+ def enabled=(_); end
56
+
57
+ def stop(*_)
58
+ @start_stop_mutex.synchronize do
59
+ Datadog.logger.debug('Requesting CpuAndWallTimeWorker thread shut down')
60
+
61
+ return unless @worker_thread
62
+
63
+ @worker_thread.kill
64
+ self.class._native_stop(self)
65
+
66
+ @worker_thread.join
67
+ @worker_thread = nil
68
+ @failure_exception = nil
69
+ end
70
+ end
71
+ end
72
+ end
73
+ end
74
+ end
@@ -1,12 +1,12 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/core/utils/only_once'
4
- require 'datadog/core/utils/time'
5
- require 'datadog/core/worker'
6
- require 'datadog/core/workers/polling'
7
- require 'datadog/profiling/backtrace_location'
8
- require 'datadog/profiling/events/stack'
9
- require 'datadog/profiling/native_extension'
3
+ require_relative '../../core/utils/only_once'
4
+ require_relative '../../core/utils/time'
5
+ require_relative '../../core/worker'
6
+ require_relative '../../core/workers/polling'
7
+ require_relative '../backtrace_location'
8
+ require_relative '../events/stack'
9
+ require_relative '../native_extension'
10
10
 
11
11
  module Datadog
12
12
  module Profiling
@@ -3,13 +3,10 @@
3
3
  module Datadog
4
4
  module Profiling
5
5
  module Collectors
6
- # Used to gather a stack trace from a given Ruby thread. Almost all of this class is implemented as native code.
6
+ # Used to gather a stack trace from a given Ruby thread. Stores its output on a `StackRecorder`.
7
7
  #
8
- # Methods prefixed with _native_ are implemented in `collectors_stack.c`
9
- class Stack
10
- def sample(thread, recorder_instance, metric_values_hash, labels_array, max_frames: 400)
11
- self.class._native_sample(thread, recorder_instance, metric_values_hash, labels_array, max_frames)
12
- end
8
+ # This class is not empty; all of this class is implemented as native code.
9
+ class Stack # rubocop:disable Lint/EmptyClass
13
10
  end
14
11
  end
15
12
  end
@@ -1,10 +1,8 @@
1
1
  # typed: true
2
2
 
3
- require 'set'
4
3
  require 'time'
5
4
 
6
- require 'datadog/profiling/flush'
7
- require 'datadog/profiling/pprof/template'
5
+ require_relative '../pprof/template'
8
6
 
9
7
  module Datadog
10
8
  module Profiling
@@ -14,31 +12,29 @@ module Datadog
14
12
  module Protobuf
15
13
  module_function
16
14
 
17
- def encode(flush)
18
- return unless flush
19
-
15
+ def encode(event_count:, event_groups:, start:, finish:)
20
16
  # Create a pprof template from the list of event types
21
- event_classes = flush.event_groups.collect(&:event_class).uniq
17
+ event_classes = event_groups.collect(&:event_class).uniq
22
18
  template = Pprof::Template.for_event_classes(event_classes)
23
19
 
24
20
  # Add all events to the pprof
25
- flush.event_groups.each { |event_group| template.add_events!(event_group.event_class, event_group.events) }
21
+ event_groups.each { |event_group| template.add_events!(event_group.event_class, event_group.events) }
26
22
 
27
23
  Datadog.logger.debug do
28
24
  max_events = Datadog.configuration.profiling.advanced.max_events
29
25
  events_sampled =
30
- if flush.event_count == max_events
26
+ if event_count == max_events
31
27
  'max events limit hit, events were sampled [profile will be biased], '
32
28
  else
33
29
  ''
34
30
  end
35
31
 
36
- "Encoding profile covering #{flush.start.iso8601} to #{flush.finish.iso8601}, " \
37
- "events: #{flush.event_count} (#{events_sampled}#{template.debug_statistics})"
32
+ "Encoding profile covering #{start.iso8601} to #{finish.iso8601}, " \
33
+ "events: #{event_count} (#{events_sampled}#{template.debug_statistics})"
38
34
  end
39
35
 
40
36
  # Build the profile and encode it
41
- template.to_pprof(start: flush.start, finish: flush.finish)
37
+ template.to_pprof(start: start, finish: finish)
42
38
  end
43
39
  end
44
40
  end
@@ -1,6 +1,6 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/profiling/event'
3
+ require_relative '../event'
4
4
 
5
5
  module Datadog
6
6
  module Profiling