ddtrace 1.2.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 (508) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +70 -0
  3. data/LICENSE-3rdparty.csv +2 -0
  4. data/README.md +1 -1
  5. data/ext/ddtrace_profiling_loader/ddtrace_profiling_loader.c +1 -1
  6. data/ext/ddtrace_profiling_native_extension/NativeExtensionDesign.md +9 -2
  7. data/ext/ddtrace_profiling_native_extension/clock_id.h +20 -0
  8. data/ext/ddtrace_profiling_native_extension/clock_id_from_pthread.c +30 -1
  9. data/ext/ddtrace_profiling_native_extension/clock_id_noop.c +10 -1
  10. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.c +152 -31
  11. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time.h +6 -0
  12. data/ext/ddtrace_profiling_native_extension/collectors_cpu_and_wall_time_worker.c +391 -0
  13. data/ext/ddtrace_profiling_native_extension/collectors_stack.c +11 -7
  14. data/ext/ddtrace_profiling_native_extension/extconf.rb +26 -19
  15. data/ext/ddtrace_profiling_native_extension/helpers.h +12 -0
  16. data/ext/ddtrace_profiling_native_extension/http_transport.c +40 -47
  17. data/ext/ddtrace_profiling_native_extension/{libddprof_helpers.h → libdatadog_helpers.h} +2 -1
  18. data/ext/ddtrace_profiling_native_extension/native_extension_helpers.rb +36 -20
  19. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.c +39 -29
  20. data/ext/ddtrace_profiling_native_extension/private_vm_api_access.h +2 -5
  21. data/ext/ddtrace_profiling_native_extension/profiling.c +4 -3
  22. data/ext/ddtrace_profiling_native_extension/ruby_helpers.c +25 -0
  23. data/ext/ddtrace_profiling_native_extension/ruby_helpers.h +33 -1
  24. data/ext/ddtrace_profiling_native_extension/stack_recorder.c +294 -19
  25. data/ext/ddtrace_profiling_native_extension/stack_recorder.h +9 -8
  26. data/lib/datadog/appsec/autoload.rb +4 -2
  27. data/lib/datadog/appsec/configuration.rb +1 -1
  28. data/lib/datadog/appsec/contrib/auto_instrument.rb +0 -2
  29. data/lib/datadog/appsec/contrib/configuration/settings.rb +1 -1
  30. data/lib/datadog/appsec/contrib/rack/configuration/settings.rb +2 -2
  31. data/lib/datadog/appsec/contrib/rack/gateway/watcher.rb +6 -6
  32. data/lib/datadog/appsec/contrib/rack/integration.rb +5 -5
  33. data/lib/datadog/appsec/contrib/rack/patcher.rb +2 -2
  34. data/lib/datadog/appsec/contrib/rack/reactive/request.rb +1 -1
  35. data/lib/datadog/appsec/contrib/rack/reactive/request_body.rb +1 -1
  36. data/lib/datadog/appsec/contrib/rack/reactive/response.rb +1 -1
  37. data/lib/datadog/appsec/contrib/rack/request_body_middleware.rb +2 -2
  38. data/lib/datadog/appsec/contrib/rack/request_middleware.rb +3 -3
  39. data/lib/datadog/appsec/contrib/rails/configuration/settings.rb +2 -2
  40. data/lib/datadog/appsec/contrib/rails/gateway/watcher.rb +4 -4
  41. data/lib/datadog/appsec/contrib/rails/integration.rb +4 -4
  42. data/lib/datadog/appsec/contrib/rails/patcher.rb +16 -12
  43. data/lib/datadog/appsec/contrib/rails/reactive/action.rb +1 -1
  44. data/lib/datadog/appsec/contrib/sinatra/configuration/settings.rb +2 -2
  45. data/lib/datadog/appsec/contrib/sinatra/gateway/watcher.rb +5 -5
  46. data/lib/datadog/appsec/contrib/sinatra/integration.rb +4 -4
  47. data/lib/datadog/appsec/contrib/sinatra/patcher.rb +16 -12
  48. data/lib/datadog/appsec/event.rb +3 -3
  49. data/lib/datadog/appsec/extensions.rb +1 -1
  50. data/lib/datadog/appsec/processor.rb +1 -1
  51. data/lib/datadog/appsec/reactive/engine.rb +2 -2
  52. data/lib/datadog/appsec/reactive/operation.rb +3 -3
  53. data/lib/datadog/appsec.rb +5 -5
  54. data/lib/datadog/ci/configuration/components.rb +1 -1
  55. data/lib/datadog/ci/configuration/settings.rb +1 -1
  56. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +2 -2
  57. data/lib/datadog/ci/contrib/cucumber/formatter.rb +5 -5
  58. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +1 -1
  59. data/lib/datadog/ci/contrib/cucumber/integration.rb +4 -4
  60. data/lib/datadog/ci/contrib/cucumber/patcher.rb +2 -2
  61. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +2 -2
  62. data/lib/datadog/ci/contrib/rspec/example.rb +5 -5
  63. data/lib/datadog/ci/contrib/rspec/integration.rb +4 -4
  64. data/lib/datadog/ci/contrib/rspec/patcher.rb +2 -2
  65. data/lib/datadog/ci/ext/environment.rb +8 -6
  66. data/lib/datadog/ci/extensions.rb +4 -4
  67. data/lib/datadog/ci/flush.rb +2 -2
  68. data/lib/datadog/ci/test.rb +3 -3
  69. data/lib/datadog/ci.rb +6 -6
  70. data/lib/datadog/core/buffer/cruby.rb +1 -1
  71. data/lib/datadog/core/buffer/thread_safe.rb +1 -1
  72. data/lib/datadog/core/configuration/agent_settings_resolver.rb +6 -6
  73. data/lib/datadog/core/configuration/base.rb +11 -2
  74. data/lib/datadog/core/configuration/components.rb +51 -48
  75. data/lib/datadog/core/configuration/option_definition.rb +1 -1
  76. data/lib/datadog/core/configuration/option_definition_set.rb +1 -1
  77. data/lib/datadog/core/configuration/options.rb +3 -3
  78. data/lib/datadog/core/configuration/settings.rb +34 -7
  79. data/lib/datadog/core/configuration.rb +8 -5
  80. data/lib/datadog/core/diagnostics/environment_logger.rb +1 -1
  81. data/lib/datadog/core/diagnostics/health.rb +2 -2
  82. data/lib/datadog/core/environment/cgroup.rb +1 -1
  83. data/lib/datadog/core/environment/container.rb +1 -1
  84. data/lib/datadog/core/environment/ext.rb +1 -1
  85. data/lib/datadog/core/environment/identity.rb +2 -2
  86. data/lib/datadog/core/environment/platform.rb +1 -1
  87. data/lib/datadog/core/environment/socket.rb +1 -1
  88. data/lib/datadog/core/error.rb +1 -1
  89. data/lib/datadog/core/extensions.rb +1 -1
  90. data/lib/datadog/core/metrics/client.rb +8 -8
  91. data/lib/datadog/core/metrics/options.rb +3 -3
  92. data/lib/datadog/core/runtime/metrics.rb +6 -6
  93. data/lib/datadog/core/telemetry/client.rb +79 -0
  94. data/lib/datadog/core/telemetry/collector.rb +234 -0
  95. data/lib/datadog/core/telemetry/emitter.rb +48 -0
  96. data/lib/datadog/core/telemetry/event.rb +71 -0
  97. data/lib/datadog/core/telemetry/ext.rb +11 -0
  98. data/lib/datadog/core/telemetry/heartbeat.rb +37 -0
  99. data/lib/datadog/core/telemetry/http/adapters/net.rb +113 -0
  100. data/lib/datadog/core/telemetry/http/env.rb +20 -0
  101. data/lib/datadog/core/telemetry/http/ext.rb +20 -0
  102. data/lib/datadog/core/telemetry/http/response.rb +68 -0
  103. data/lib/datadog/core/telemetry/http/transport.rb +53 -0
  104. data/lib/datadog/core/telemetry/v1/app_event.rb +52 -0
  105. data/lib/datadog/core/telemetry/v1/application.rb +86 -0
  106. data/lib/datadog/core/telemetry/v1/configuration.rb +25 -0
  107. data/lib/datadog/core/telemetry/v1/dependency.rb +36 -0
  108. data/lib/datadog/core/telemetry/v1/host.rb +51 -0
  109. data/lib/datadog/core/telemetry/v1/integration.rb +58 -0
  110. data/lib/datadog/core/telemetry/v1/product.rb +28 -0
  111. data/lib/datadog/core/telemetry/v1/telemetry_request.rb +100 -0
  112. data/lib/datadog/core/utils/object_set.rb +1 -1
  113. data/lib/datadog/core/utils/sequence.rb +5 -0
  114. data/lib/datadog/core/utils/string_table.rb +1 -1
  115. data/lib/datadog/core/utils/time.rb +3 -3
  116. data/lib/datadog/core/utils.rb +2 -2
  117. data/lib/datadog/core/vendor/multipart-post/multipart/post/multipartable.rb +2 -2
  118. data/lib/datadog/core/vendor/multipart-post/net/http/post/multipart.rb +3 -3
  119. data/lib/datadog/core/workers/async.rb +1 -1
  120. data/lib/datadog/core/workers/polling.rb +2 -2
  121. data/lib/datadog/core/workers/runtime_metrics.rb +4 -4
  122. data/lib/datadog/core.rb +50 -50
  123. data/lib/datadog/kit.rb +1 -1
  124. data/lib/datadog/opentracer/distributed_headers.rb +2 -2
  125. data/lib/datadog/opentracer/rack_propagator.rb +11 -7
  126. data/lib/datadog/opentracer/span.rb +1 -1
  127. data/lib/datadog/opentracer/text_map_propagator.rb +9 -6
  128. data/lib/datadog/opentracer/thread_local_scope_manager.rb +1 -1
  129. data/lib/datadog/opentracer/tracer.rb +19 -15
  130. data/lib/datadog/opentracer.rb +16 -16
  131. data/lib/datadog/profiling/buffer.rb +3 -3
  132. data/lib/datadog/profiling/collectors/cpu_and_wall_time.rb +4 -19
  133. data/lib/datadog/profiling/collectors/cpu_and_wall_time_worker.rb +74 -0
  134. data/lib/datadog/profiling/collectors/old_stack.rb +7 -7
  135. data/lib/datadog/profiling/collectors/stack.rb +3 -8
  136. data/lib/datadog/profiling/encoding/profile.rb +1 -1
  137. data/lib/datadog/profiling/events/stack.rb +1 -1
  138. data/lib/datadog/profiling/exporter.rb +17 -9
  139. data/lib/datadog/profiling/ext/forking.rb +36 -37
  140. data/lib/datadog/profiling/ext.rb +1 -0
  141. data/lib/datadog/profiling/flush.rb +0 -3
  142. data/lib/datadog/profiling/http_transport.rb +4 -3
  143. data/lib/datadog/profiling/old_recorder.rb +2 -7
  144. data/lib/datadog/profiling/pprof/builder.rb +4 -4
  145. data/lib/datadog/profiling/pprof/converter.rb +1 -1
  146. data/lib/datadog/profiling/pprof/message_set.rb +1 -1
  147. data/lib/datadog/profiling/pprof/stack_sample.rb +4 -4
  148. data/lib/datadog/profiling/pprof/string_table.rb +1 -1
  149. data/lib/datadog/profiling/pprof/template.rb +5 -5
  150. data/lib/datadog/profiling/preload.rb +1 -1
  151. data/lib/datadog/profiling/scheduler.rb +5 -4
  152. data/lib/datadog/profiling/stack_recorder.rb +14 -4
  153. data/lib/datadog/profiling/tag_builder.rb +6 -1
  154. data/lib/datadog/profiling/tasks/setup.rb +2 -2
  155. data/lib/datadog/profiling/trace_identifiers/ddtrace.rb +2 -2
  156. data/lib/datadog/profiling/trace_identifiers/helper.rb +1 -1
  157. data/lib/datadog/profiling/transport/http/api/endpoint.rb +5 -5
  158. data/lib/datadog/profiling/transport/http/api/instance.rb +2 -2
  159. data/lib/datadog/profiling/transport/http/api/spec.rb +1 -1
  160. data/lib/datadog/profiling/transport/http/api.rb +5 -5
  161. data/lib/datadog/profiling/transport/http/builder.rb +3 -3
  162. data/lib/datadog/profiling/transport/http/client.rb +2 -2
  163. data/lib/datadog/profiling/transport/http/response.rb +1 -1
  164. data/lib/datadog/profiling/transport/http.rb +21 -15
  165. data/lib/datadog/profiling.rb +21 -20
  166. data/lib/datadog/tracing/analytics.rb +1 -1
  167. data/lib/datadog/tracing/buffer.rb +5 -5
  168. data/lib/datadog/tracing/context.rb +1 -1
  169. data/lib/datadog/tracing/context_provider.rb +2 -2
  170. data/lib/datadog/tracing/contrib/action_cable/configuration/settings.rb +2 -2
  171. data/lib/datadog/tracing/contrib/action_cable/event.rb +4 -5
  172. data/lib/datadog/tracing/contrib/action_cable/events/broadcast.rb +4 -4
  173. data/lib/datadog/tracing/contrib/action_cable/events/perform_action.rb +3 -3
  174. data/lib/datadog/tracing/contrib/action_cable/events/transmit.rb +4 -4
  175. data/lib/datadog/tracing/contrib/action_cable/events.rb +4 -4
  176. data/lib/datadog/tracing/contrib/action_cable/instrumentation.rb +3 -4
  177. data/lib/datadog/tracing/contrib/action_cable/integration.rb +4 -4
  178. data/lib/datadog/tracing/contrib/action_cable/patcher.rb +4 -4
  179. data/lib/datadog/tracing/contrib/action_mailer/configuration/settings.rb +2 -2
  180. data/lib/datadog/tracing/contrib/action_mailer/event.rb +3 -3
  181. data/lib/datadog/tracing/contrib/action_mailer/events/deliver.rb +3 -3
  182. data/lib/datadog/tracing/contrib/action_mailer/events/process.rb +3 -3
  183. data/lib/datadog/tracing/contrib/action_mailer/events.rb +2 -2
  184. data/lib/datadog/tracing/contrib/action_mailer/integration.rb +4 -4
  185. data/lib/datadog/tracing/contrib/action_mailer/patcher.rb +3 -3
  186. data/lib/datadog/tracing/contrib/action_pack/action_controller/instrumentation.rb +6 -6
  187. data/lib/datadog/tracing/contrib/action_pack/action_controller/patcher.rb +2 -2
  188. data/lib/datadog/tracing/contrib/action_pack/configuration/settings.rb +2 -2
  189. data/lib/datadog/tracing/contrib/action_pack/integration.rb +4 -4
  190. data/lib/datadog/tracing/contrib/action_pack/patcher.rb +2 -2
  191. data/lib/datadog/tracing/contrib/action_pack/utils.rb +1 -1
  192. data/lib/datadog/tracing/contrib/action_view/configuration/settings.rb +2 -2
  193. data/lib/datadog/tracing/contrib/action_view/event.rb +1 -1
  194. data/lib/datadog/tracing/contrib/action_view/events/render_partial.rb +5 -5
  195. data/lib/datadog/tracing/contrib/action_view/events/render_template.rb +5 -5
  196. data/lib/datadog/tracing/contrib/action_view/events.rb +2 -2
  197. data/lib/datadog/tracing/contrib/action_view/instrumentation/partial_renderer.rb +2 -2
  198. data/lib/datadog/tracing/contrib/action_view/instrumentation/template_renderer.rb +2 -2
  199. data/lib/datadog/tracing/contrib/action_view/integration.rb +4 -4
  200. data/lib/datadog/tracing/contrib/action_view/patcher.rb +7 -7
  201. data/lib/datadog/tracing/contrib/action_view/utils.rb +1 -1
  202. data/lib/datadog/tracing/contrib/active_job/configuration/settings.rb +3 -3
  203. data/lib/datadog/tracing/contrib/active_job/event.rb +3 -3
  204. data/lib/datadog/tracing/contrib/active_job/events/discard.rb +4 -4
  205. data/lib/datadog/tracing/contrib/active_job/events/enqueue.rb +4 -4
  206. data/lib/datadog/tracing/contrib/active_job/events/enqueue_at.rb +4 -4
  207. data/lib/datadog/tracing/contrib/active_job/events/enqueue_retry.rb +4 -4
  208. data/lib/datadog/tracing/contrib/active_job/events/perform.rb +4 -4
  209. data/lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb +4 -4
  210. data/lib/datadog/tracing/contrib/active_job/events.rb +6 -6
  211. data/lib/datadog/tracing/contrib/active_job/integration.rb +4 -4
  212. data/lib/datadog/tracing/contrib/active_job/log_injection.rb +0 -2
  213. data/lib/datadog/tracing/contrib/active_job/patcher.rb +4 -4
  214. data/lib/datadog/tracing/contrib/active_model_serializers/configuration/settings.rb +2 -2
  215. data/lib/datadog/tracing/contrib/active_model_serializers/event.rb +4 -5
  216. data/lib/datadog/tracing/contrib/active_model_serializers/events/render.rb +3 -3
  217. data/lib/datadog/tracing/contrib/active_model_serializers/events/serialize.rb +2 -2
  218. data/lib/datadog/tracing/contrib/active_model_serializers/events.rb +2 -2
  219. data/lib/datadog/tracing/contrib/active_model_serializers/integration.rb +3 -3
  220. data/lib/datadog/tracing/contrib/active_model_serializers/patcher.rb +3 -4
  221. data/lib/datadog/tracing/contrib/active_record/configuration/resolver.rb +2 -2
  222. data/lib/datadog/tracing/contrib/active_record/configuration/settings.rb +3 -3
  223. data/lib/datadog/tracing/contrib/active_record/event.rb +1 -1
  224. data/lib/datadog/tracing/contrib/active_record/events/instantiation.rb +4 -4
  225. data/lib/datadog/tracing/contrib/active_record/events/sql.rb +6 -6
  226. data/lib/datadog/tracing/contrib/active_record/events.rb +2 -2
  227. data/lib/datadog/tracing/contrib/active_record/integration.rb +6 -6
  228. data/lib/datadog/tracing/contrib/active_record/patcher.rb +2 -2
  229. data/lib/datadog/tracing/contrib/active_record/utils.rb +2 -2
  230. data/lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb +19 -9
  231. data/lib/datadog/tracing/contrib/active_support/cache/patcher.rb +2 -2
  232. data/lib/datadog/tracing/contrib/active_support/cache/redis.rb +1 -1
  233. data/lib/datadog/tracing/contrib/active_support/configuration/settings.rb +2 -2
  234. data/lib/datadog/tracing/contrib/active_support/integration.rb +5 -5
  235. data/lib/datadog/tracing/contrib/active_support/notifications/event.rb +1 -1
  236. data/lib/datadog/tracing/contrib/active_support/notifications/subscriber.rb +1 -1
  237. data/lib/datadog/tracing/contrib/active_support/patcher.rb +2 -2
  238. data/lib/datadog/tracing/contrib/analytics.rb +1 -1
  239. data/lib/datadog/tracing/contrib/auto_instrument.rb +4 -4
  240. data/lib/datadog/tracing/contrib/aws/configuration/settings.rb +2 -2
  241. data/lib/datadog/tracing/contrib/aws/instrumentation.rb +3 -4
  242. data/lib/datadog/tracing/contrib/aws/integration.rb +3 -3
  243. data/lib/datadog/tracing/contrib/aws/patcher.rb +5 -5
  244. data/lib/datadog/tracing/contrib/concurrent_ruby/configuration/settings.rb +2 -2
  245. data/lib/datadog/tracing/contrib/concurrent_ruby/future_patch.rb +1 -1
  246. data/lib/datadog/tracing/contrib/concurrent_ruby/integration.rb +3 -3
  247. data/lib/datadog/tracing/contrib/concurrent_ruby/patcher.rb +2 -2
  248. data/lib/datadog/tracing/contrib/configurable.rb +2 -2
  249. data/lib/datadog/tracing/contrib/configuration/resolvers/pattern_resolver.rb +1 -1
  250. data/lib/datadog/tracing/contrib/configuration/settings.rb +2 -2
  251. data/lib/datadog/tracing/contrib/dalli/configuration/settings.rb +2 -2
  252. data/lib/datadog/tracing/contrib/dalli/instrumentation.rb +4 -5
  253. data/lib/datadog/tracing/contrib/dalli/integration.rb +3 -3
  254. data/lib/datadog/tracing/contrib/dalli/patcher.rb +3 -3
  255. data/lib/datadog/tracing/contrib/dalli/quantize.rb +1 -1
  256. data/lib/datadog/tracing/contrib/delayed_job/configuration/settings.rb +3 -3
  257. data/lib/datadog/tracing/contrib/delayed_job/ext.rb +2 -0
  258. data/lib/datadog/tracing/contrib/delayed_job/integration.rb +3 -3
  259. data/lib/datadog/tracing/contrib/delayed_job/patcher.rb +8 -2
  260. data/lib/datadog/tracing/contrib/delayed_job/plugin.rb +3 -4
  261. data/lib/datadog/tracing/contrib/delayed_job/server_internal_tracer/worker.rb +32 -0
  262. data/lib/datadog/tracing/contrib/elasticsearch/configuration/settings.rb +2 -2
  263. data/lib/datadog/tracing/contrib/elasticsearch/integration.rb +3 -3
  264. data/lib/datadog/tracing/contrib/elasticsearch/patcher.rb +6 -7
  265. data/lib/datadog/tracing/contrib/elasticsearch/quantize.rb +1 -1
  266. data/lib/datadog/tracing/contrib/ethon/configuration/settings.rb +2 -2
  267. data/lib/datadog/tracing/contrib/ethon/easy_patch.rb +4 -5
  268. data/lib/datadog/tracing/contrib/ethon/integration.rb +4 -4
  269. data/lib/datadog/tracing/contrib/ethon/multi_patch.rb +3 -4
  270. data/lib/datadog/tracing/contrib/ethon/patcher.rb +3 -3
  271. data/lib/datadog/tracing/contrib/excon/configuration/settings.rb +2 -2
  272. data/lib/datadog/tracing/contrib/excon/integration.rb +4 -4
  273. data/lib/datadog/tracing/contrib/excon/middleware.rb +6 -7
  274. data/lib/datadog/tracing/contrib/excon/patcher.rb +2 -2
  275. data/lib/datadog/tracing/contrib/extensions.rb +5 -3
  276. data/lib/datadog/tracing/contrib/faraday/configuration/settings.rb +2 -2
  277. data/lib/datadog/tracing/contrib/faraday/integration.rb +4 -4
  278. data/lib/datadog/tracing/contrib/faraday/middleware.rb +5 -6
  279. data/lib/datadog/tracing/contrib/faraday/patcher.rb +5 -5
  280. data/lib/datadog/tracing/contrib/grape/configuration/settings.rb +3 -3
  281. data/lib/datadog/tracing/contrib/grape/endpoint.rb +4 -5
  282. data/lib/datadog/tracing/contrib/grape/integration.rb +3 -3
  283. data/lib/datadog/tracing/contrib/grape/patcher.rb +4 -4
  284. data/lib/datadog/tracing/contrib/graphql/configuration/settings.rb +2 -2
  285. data/lib/datadog/tracing/contrib/graphql/integration.rb +3 -3
  286. data/lib/datadog/tracing/contrib/graphql/patcher.rb +2 -3
  287. data/lib/datadog/tracing/contrib/grpc/configuration/settings.rb +3 -3
  288. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/client.rb +13 -4
  289. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor/server.rb +6 -6
  290. data/lib/datadog/tracing/contrib/grpc/datadog_interceptor.rb +3 -4
  291. data/lib/datadog/tracing/contrib/grpc/ext.rb +1 -0
  292. data/lib/datadog/tracing/contrib/grpc/integration.rb +3 -3
  293. data/lib/datadog/tracing/contrib/grpc/patcher.rb +5 -5
  294. data/lib/datadog/tracing/contrib/http/circuit_breaker.rb +1 -2
  295. data/lib/datadog/tracing/contrib/http/configuration/settings.rb +2 -2
  296. data/lib/datadog/tracing/contrib/http/instrumentation.rb +3 -4
  297. data/lib/datadog/tracing/contrib/http/integration.rb +6 -6
  298. data/lib/datadog/tracing/contrib/http/patcher.rb +3 -3
  299. data/lib/datadog/tracing/contrib/httpclient/configuration/settings.rb +2 -2
  300. data/lib/datadog/tracing/contrib/httpclient/instrumentation.rb +4 -5
  301. data/lib/datadog/tracing/contrib/httpclient/integration.rb +4 -4
  302. data/lib/datadog/tracing/contrib/httpclient/patcher.rb +3 -3
  303. data/lib/datadog/tracing/contrib/httprb/configuration/settings.rb +2 -2
  304. data/lib/datadog/tracing/contrib/httprb/instrumentation.rb +4 -5
  305. data/lib/datadog/tracing/contrib/httprb/integration.rb +4 -4
  306. data/lib/datadog/tracing/contrib/httprb/patcher.rb +3 -3
  307. data/lib/datadog/tracing/contrib/integration.rb +3 -3
  308. data/lib/datadog/tracing/contrib/kafka/configuration/settings.rb +2 -2
  309. data/lib/datadog/tracing/contrib/kafka/event.rb +3 -3
  310. data/lib/datadog/tracing/contrib/kafka/events/connection/request.rb +2 -2
  311. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_batch.rb +3 -3
  312. data/lib/datadog/tracing/contrib/kafka/events/consumer/process_message.rb +3 -3
  313. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/heartbeat.rb +4 -4
  314. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/join_group.rb +4 -4
  315. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/leave_group.rb +4 -4
  316. data/lib/datadog/tracing/contrib/kafka/events/consumer_group/sync_group.rb +4 -4
  317. data/lib/datadog/tracing/contrib/kafka/events/produce_operation/send_messages.rb +2 -2
  318. data/lib/datadog/tracing/contrib/kafka/events/producer/deliver_messages.rb +2 -2
  319. data/lib/datadog/tracing/contrib/kafka/events.rb +9 -9
  320. data/lib/datadog/tracing/contrib/kafka/integration.rb +3 -3
  321. data/lib/datadog/tracing/contrib/kafka/patcher.rb +3 -3
  322. data/lib/datadog/tracing/contrib/lograge/configuration/settings.rb +2 -2
  323. data/lib/datadog/tracing/contrib/lograge/instrumentation.rb +1 -2
  324. data/lib/datadog/tracing/contrib/lograge/integration.rb +3 -3
  325. data/lib/datadog/tracing/contrib/lograge/patcher.rb +2 -2
  326. data/lib/datadog/tracing/contrib/mongodb/configuration/settings.rb +2 -2
  327. data/lib/datadog/tracing/contrib/mongodb/instrumentation.rb +3 -3
  328. data/lib/datadog/tracing/contrib/mongodb/integration.rb +4 -4
  329. data/lib/datadog/tracing/contrib/mongodb/parsers.rb +1 -1
  330. data/lib/datadog/tracing/contrib/mongodb/patcher.rb +3 -3
  331. data/lib/datadog/tracing/contrib/mongodb/subscribers.rb +4 -4
  332. data/lib/datadog/tracing/contrib/mysql2/configuration/settings.rb +2 -2
  333. data/lib/datadog/tracing/contrib/mysql2/instrumentation.rb +3 -4
  334. data/lib/datadog/tracing/contrib/mysql2/integration.rb +3 -3
  335. data/lib/datadog/tracing/contrib/mysql2/patcher.rb +2 -2
  336. data/lib/datadog/tracing/contrib/patcher.rb +13 -2
  337. data/lib/datadog/tracing/contrib/pg/configuration/settings.rb +2 -2
  338. data/lib/datadog/tracing/contrib/pg/instrumentation.rb +3 -4
  339. data/lib/datadog/tracing/contrib/pg/integration.rb +3 -3
  340. data/lib/datadog/tracing/contrib/pg/patcher.rb +2 -2
  341. data/lib/datadog/tracing/contrib/presto/configuration/settings.rb +2 -2
  342. data/lib/datadog/tracing/contrib/presto/instrumentation.rb +2 -3
  343. data/lib/datadog/tracing/contrib/presto/integration.rb +3 -3
  344. data/lib/datadog/tracing/contrib/presto/patcher.rb +4 -4
  345. data/lib/datadog/tracing/contrib/qless/configuration/settings.rb +2 -2
  346. data/lib/datadog/tracing/contrib/qless/integration.rb +3 -3
  347. data/lib/datadog/tracing/contrib/qless/patcher.rb +1 -2
  348. data/lib/datadog/tracing/contrib/qless/qless_job.rb +2 -3
  349. data/lib/datadog/tracing/contrib/qless/tracer_cleaner.rb +0 -2
  350. data/lib/datadog/tracing/contrib/que/configuration/settings.rb +3 -3
  351. data/lib/datadog/tracing/contrib/que/integration.rb +4 -4
  352. data/lib/datadog/tracing/contrib/que/patcher.rb +1 -1
  353. data/lib/datadog/tracing/contrib/que/tracer.rb +1 -1
  354. data/lib/datadog/tracing/contrib/racecar/configuration/settings.rb +2 -2
  355. data/lib/datadog/tracing/contrib/racecar/event.rb +4 -5
  356. data/lib/datadog/tracing/contrib/racecar/events/batch.rb +2 -2
  357. data/lib/datadog/tracing/contrib/racecar/events/consume.rb +2 -2
  358. data/lib/datadog/tracing/contrib/racecar/events/message.rb +2 -2
  359. data/lib/datadog/tracing/contrib/racecar/events.rb +3 -3
  360. data/lib/datadog/tracing/contrib/racecar/integration.rb +3 -3
  361. data/lib/datadog/tracing/contrib/racecar/patcher.rb +3 -3
  362. data/lib/datadog/tracing/contrib/rack/configuration/settings.rb +2 -2
  363. data/lib/datadog/tracing/contrib/rack/integration.rb +4 -4
  364. data/lib/datadog/tracing/contrib/rack/middlewares.rb +24 -20
  365. data/lib/datadog/tracing/contrib/rack/patcher.rb +12 -2
  366. data/lib/datadog/tracing/contrib/rails/auto_instrument_railtie.rb +1 -1
  367. data/lib/datadog/tracing/contrib/rails/configuration/settings.rb +1 -1
  368. data/lib/datadog/tracing/contrib/rails/framework.rb +16 -21
  369. data/lib/datadog/tracing/contrib/rails/integration.rb +4 -4
  370. data/lib/datadog/tracing/contrib/rails/log_injection.rb +0 -2
  371. data/lib/datadog/tracing/contrib/rails/middlewares.rb +1 -2
  372. data/lib/datadog/tracing/contrib/rails/patcher.rb +7 -8
  373. data/lib/datadog/tracing/contrib/rails/railtie.rb +3 -3
  374. data/lib/datadog/tracing/contrib/rails/utils.rb +1 -1
  375. data/lib/datadog/tracing/contrib/rake/configuration/settings.rb +17 -2
  376. data/lib/datadog/tracing/contrib/rake/instrumentation.rb +12 -7
  377. data/lib/datadog/tracing/contrib/rake/integration.rb +3 -3
  378. data/lib/datadog/tracing/contrib/rake/patcher.rb +3 -4
  379. data/lib/datadog/tracing/contrib/redis/configuration/resolver.rb +1 -1
  380. data/lib/datadog/tracing/contrib/redis/configuration/settings.rb +2 -2
  381. data/lib/datadog/tracing/contrib/redis/instrumentation.rb +6 -7
  382. data/lib/datadog/tracing/contrib/redis/integration.rb +3 -3
  383. data/lib/datadog/tracing/contrib/redis/patcher.rb +6 -6
  384. data/lib/datadog/tracing/contrib/redis/tags.rb +3 -4
  385. data/lib/datadog/tracing/contrib/resque/configuration/settings.rb +3 -3
  386. data/lib/datadog/tracing/contrib/resque/integration.rb +3 -3
  387. data/lib/datadog/tracing/contrib/resque/patcher.rb +2 -2
  388. data/lib/datadog/tracing/contrib/resque/resque_job.rb +3 -4
  389. data/lib/datadog/tracing/contrib/rest_client/configuration/settings.rb +2 -2
  390. data/lib/datadog/tracing/contrib/rest_client/integration.rb +3 -3
  391. data/lib/datadog/tracing/contrib/rest_client/patcher.rb +2 -2
  392. data/lib/datadog/tracing/contrib/rest_client/request_patch.rb +4 -5
  393. data/lib/datadog/tracing/contrib/semantic_logger/configuration/settings.rb +2 -2
  394. data/lib/datadog/tracing/contrib/semantic_logger/instrumentation.rb +1 -2
  395. data/lib/datadog/tracing/contrib/semantic_logger/integration.rb +3 -3
  396. data/lib/datadog/tracing/contrib/semantic_logger/patcher.rb +2 -2
  397. data/lib/datadog/tracing/contrib/sequel/configuration/settings.rb +2 -2
  398. data/lib/datadog/tracing/contrib/sequel/database.rb +4 -5
  399. data/lib/datadog/tracing/contrib/sequel/dataset.rb +4 -5
  400. data/lib/datadog/tracing/contrib/sequel/integration.rb +3 -3
  401. data/lib/datadog/tracing/contrib/sequel/patcher.rb +3 -3
  402. data/lib/datadog/tracing/contrib/sequel/utils.rb +2 -2
  403. data/lib/datadog/tracing/contrib/shoryuken/configuration/settings.rb +3 -3
  404. data/lib/datadog/tracing/contrib/shoryuken/integration.rb +4 -4
  405. data/lib/datadog/tracing/contrib/shoryuken/patcher.rb +1 -1
  406. data/lib/datadog/tracing/contrib/shoryuken/tracer.rb +1 -1
  407. data/lib/datadog/tracing/contrib/sidekiq/client_tracer.rb +4 -5
  408. data/lib/datadog/tracing/contrib/sidekiq/configuration/settings.rb +3 -3
  409. data/lib/datadog/tracing/contrib/sidekiq/ext.rb +6 -0
  410. data/lib/datadog/tracing/contrib/sidekiq/integration.rb +3 -3
  411. data/lib/datadog/tracing/contrib/sidekiq/patcher.rb +14 -7
  412. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/heartbeat.rb +19 -1
  413. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/{scheduled_push.rb → redis_info.rb} +5 -6
  414. data/lib/datadog/tracing/contrib/sidekiq/server_internal_tracer/scheduled_poller.rb +53 -0
  415. data/lib/datadog/tracing/contrib/sidekiq/server_tracer.rb +5 -6
  416. data/lib/datadog/tracing/contrib/sidekiq/tracing.rb +2 -2
  417. data/lib/datadog/tracing/contrib/sinatra/configuration/settings.rb +2 -2
  418. data/lib/datadog/tracing/contrib/sinatra/env.rb +2 -2
  419. data/lib/datadog/tracing/contrib/sinatra/framework.rb +0 -2
  420. data/lib/datadog/tracing/contrib/sinatra/headers.rb +1 -1
  421. data/lib/datadog/tracing/contrib/sinatra/integration.rb +3 -3
  422. data/lib/datadog/tracing/contrib/sinatra/patcher.rb +5 -5
  423. data/lib/datadog/tracing/contrib/sinatra/tracer.rb +7 -8
  424. data/lib/datadog/tracing/contrib/sinatra/tracer_middleware.rb +6 -7
  425. data/lib/datadog/tracing/contrib/sneakers/configuration/settings.rb +2 -2
  426. data/lib/datadog/tracing/contrib/sneakers/integration.rb +4 -4
  427. data/lib/datadog/tracing/contrib/sneakers/patcher.rb +2 -2
  428. data/lib/datadog/tracing/contrib/sneakers/tracer.rb +2 -3
  429. data/lib/datadog/tracing/contrib/status_code_matcher.rb +2 -2
  430. data/lib/datadog/tracing/contrib/sucker_punch/configuration/settings.rb +2 -2
  431. data/lib/datadog/tracing/contrib/sucker_punch/instrumentation.rb +3 -4
  432. data/lib/datadog/tracing/contrib/sucker_punch/integration.rb +3 -3
  433. data/lib/datadog/tracing/contrib/sucker_punch/patcher.rb +4 -5
  434. data/lib/datadog/tracing/contrib.rb +48 -48
  435. data/lib/datadog/tracing/correlation.rb +1 -1
  436. data/lib/datadog/tracing/distributed/headers/b3.rb +4 -4
  437. data/lib/datadog/tracing/distributed/headers/b3_single.rb +4 -4
  438. data/lib/datadog/tracing/distributed/headers/datadog.rb +3 -3
  439. data/lib/datadog/tracing/distributed/headers/parser.rb +1 -1
  440. data/lib/datadog/tracing/distributed/helpers.rb +2 -2
  441. data/lib/datadog/tracing/distributed/metadata/b3.rb +4 -4
  442. data/lib/datadog/tracing/distributed/metadata/b3_single.rb +4 -4
  443. data/lib/datadog/tracing/distributed/metadata/datadog.rb +2 -2
  444. data/lib/datadog/tracing/distributed/metadata/parser.rb +1 -1
  445. data/lib/datadog/tracing/event.rb +1 -1
  446. data/lib/datadog/tracing/metadata/analytics.rb +2 -2
  447. data/lib/datadog/tracing/metadata/errors.rb +2 -2
  448. data/lib/datadog/tracing/metadata/tagging.rb +2 -2
  449. data/lib/datadog/tracing/metadata.rb +3 -3
  450. data/lib/datadog/tracing/pipeline/span_filter.rb +10 -6
  451. data/lib/datadog/tracing/pipeline.rb +3 -3
  452. data/lib/datadog/tracing/propagation/grpc.rb +6 -6
  453. data/lib/datadog/tracing/propagation/http.rb +8 -8
  454. data/lib/datadog/tracing/runtime/metrics.rb +1 -1
  455. data/lib/datadog/tracing/sampling/all_sampler.rb +1 -1
  456. data/lib/datadog/tracing/sampling/priority_sampler.rb +5 -5
  457. data/lib/datadog/tracing/sampling/rate_by_key_sampler.rb +2 -2
  458. data/lib/datadog/tracing/sampling/rate_by_service_sampler.rb +3 -3
  459. data/lib/datadog/tracing/sampling/rate_limiter.rb +1 -1
  460. data/lib/datadog/tracing/sampling/rate_sampler.rb +5 -5
  461. data/lib/datadog/tracing/sampling/rule.rb +3 -3
  462. data/lib/datadog/tracing/sampling/rule_sampler.rb +4 -4
  463. data/lib/datadog/tracing/span.rb +4 -4
  464. data/lib/datadog/tracing/span_operation.rb +9 -9
  465. data/lib/datadog/tracing/sync_writer.rb +5 -5
  466. data/lib/datadog/tracing/trace_operation.rb +16 -9
  467. data/lib/datadog/tracing/trace_segment.rb +5 -5
  468. data/lib/datadog/tracing/tracer.rb +15 -15
  469. data/lib/datadog/tracing/workers/trace_writer.rb +9 -9
  470. data/lib/datadog/tracing/workers.rb +3 -3
  471. data/lib/datadog/tracing/writer.rb +5 -5
  472. data/lib/datadog/tracing.rb +8 -8
  473. data/lib/ddtrace/auto_instrument.rb +9 -2
  474. data/lib/ddtrace/transport/ext.rb +7 -1
  475. data/lib/ddtrace/transport/http/adapters/net.rb +3 -2
  476. data/lib/ddtrace/transport/http/adapters/test.rb +1 -1
  477. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +2 -2
  478. data/lib/ddtrace/transport/http/api/map.rb +1 -1
  479. data/lib/ddtrace/transport/http/api.rb +4 -4
  480. data/lib/ddtrace/transport/http/builder.rb +5 -5
  481. data/lib/ddtrace/transport/http/client.rb +2 -2
  482. data/lib/ddtrace/transport/http/response.rb +1 -1
  483. data/lib/ddtrace/transport/http/statistics.rb +1 -1
  484. data/lib/ddtrace/transport/http/traces.rb +5 -5
  485. data/lib/ddtrace/transport/http.rb +12 -9
  486. data/lib/ddtrace/transport/io/client.rb +2 -2
  487. data/lib/ddtrace/transport/io/response.rb +1 -1
  488. data/lib/ddtrace/transport/io/traces.rb +3 -3
  489. data/lib/ddtrace/transport/io.rb +3 -3
  490. data/lib/ddtrace/transport/statistics.rb +2 -2
  491. data/lib/ddtrace/transport/trace_formatter.rb +5 -5
  492. data/lib/ddtrace/transport/traces.rb +5 -5
  493. data/lib/ddtrace/version.rb +1 -1
  494. data/lib/ddtrace.rb +6 -6
  495. metadata +35 -22
  496. data/.editorconfig +0 -22
  497. data/.gitignore +0 -58
  498. data/CONTRIBUTING.md +0 -81
  499. data/ddtrace.gemspec +0 -71
  500. data/docs/0.x-trace.png +0 -0
  501. data/docs/1.0-trace.png +0 -0
  502. data/docs/AutoInstrumentation.md +0 -36
  503. data/docs/Deprecation.md +0 -8
  504. data/docs/DevelopmentGuide.md +0 -259
  505. data/docs/GettingStarted.md +0 -2712
  506. data/docs/ProfilingDevelopment.md +0 -109
  507. data/docs/PublicApi.md +0 -14
  508. data/docs/UpgradeGuide.md +0 -736
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,6 +1,6 @@
1
1
  # typed: false
2
2
 
3
- require 'datadog/core/utils/sequence'
3
+ require_relative '../core/utils/sequence'
4
4
 
5
5
  module Datadog
6
6
  module OpenTracer
@@ -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
@@ -3,8 +3,11 @@
3
3
  module Datadog
4
4
  module Profiling
5
5
  module Collectors
6
- # Used to periodically (time-based) sample threads, recording elapsed CPU-time and Wall-time between samples.
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.
7
9
  # The stack collection itself is handled using the Datadog::Profiling::Collectors::Stack.
10
+ # Almost all of this class is implemented as native code.
8
11
  #
9
12
  # Methods prefixed with _native_ are implemented in `collectors_cpu_and_wall_time.c`
10
13
  class CpuAndWallTime
@@ -12,24 +15,6 @@ module Datadog
12
15
  self.class._native_initialize(self, recorder, max_frames)
13
16
  end
14
17
 
15
- # This method exists only to enable testing Datadog::Profiling::Collectors::CpuAndWallTime behavior using RSpec.
16
- # It SHOULD NOT be used for other purposes.
17
- def sample
18
- self.class._native_sample(self)
19
- end
20
-
21
- # This method exists only to enable testing Datadog::Profiling::Collectors::CpuAndWallTime behavior using RSpec.
22
- # It SHOULD NOT be used for other purposes.
23
- def thread_list
24
- self.class._native_thread_list
25
- end
26
-
27
- # This method exists only to enable testing Datadog::Profiling::Collectors::CpuAndWallTime behavior using RSpec.
28
- # It SHOULD NOT be used for other purposes.
29
- def per_thread_context
30
- self.class._native_per_thread_context(self)
31
- end
32
-
33
18
  def inspect
34
19
  # Compose Ruby's default inspect with our custom inspect for the native parts
35
20
  result = super()
@@ -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,15 +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
- # This method exists only to enable testing Datadog::Profiling::Collectors::Stack behavior using RSpec.
11
- # It SHOULD NOT be used for other purposes.
12
- def sample(thread, recorder_instance, metric_values_hash, labels_array, max_frames: 400)
13
- self.class._native_sample(thread, recorder_instance, metric_values_hash, labels_array, max_frames)
14
- end
8
+ # This class is not empty; all of this class is implemented as native code.
9
+ class Stack # rubocop:disable Lint/EmptyClass
15
10
  end
16
11
  end
17
12
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  require 'time'
4
4
 
5
- require 'datadog/profiling/pprof/template'
5
+ require_relative '../pprof/template'
6
6
 
7
7
  module Datadog
8
8
  module Profiling
@@ -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
@@ -1,8 +1,8 @@
1
1
  # typed: true
2
2
 
3
- require 'datadog/profiling/ext'
4
- require 'datadog/core/utils/compression'
5
- require 'datadog/profiling/tag_builder'
3
+ require_relative 'ext'
4
+ require_relative '../core/utils/compression'
5
+ require_relative 'tag_builder'
6
6
 
7
7
  module Datadog
8
8
  module Profiling
@@ -22,22 +22,30 @@ module Datadog
22
22
  attr_reader \
23
23
  :pprof_recorder,
24
24
  :code_provenance_collector, # The code provenance collector acts both as collector and as a recorder
25
- :minimum_duration
25
+ :minimum_duration_seconds,
26
+ :time_provider,
27
+ :last_flush_finish_at,
28
+ :created_at
26
29
 
27
30
  public
28
31
 
29
32
  def initialize(
30
33
  pprof_recorder:,
31
34
  code_provenance_collector:,
32
- minimum_duration: PROFILE_DURATION_THRESHOLD_SECONDS
35
+ minimum_duration_seconds: PROFILE_DURATION_THRESHOLD_SECONDS,
36
+ time_provider: Time
33
37
  )
34
38
  @pprof_recorder = pprof_recorder
35
39
  @code_provenance_collector = code_provenance_collector
36
- @minimum_duration = minimum_duration
40
+ @minimum_duration_seconds = minimum_duration_seconds
41
+ @time_provider = time_provider
42
+ @last_flush_finish_at = nil
43
+ @created_at = time_provider.now.utc
37
44
  end
38
45
 
39
46
  def flush
40
47
  start, finish, uncompressed_pprof = pprof_recorder.serialize
48
+ @last_flush_finish_at = finish
41
49
 
42
50
  return if uncompressed_pprof.nil? # We don't want to report empty profiles
43
51
 
@@ -60,14 +68,14 @@ module Datadog
60
68
  )
61
69
  end
62
70
 
63
- def empty?
64
- pprof_recorder.empty?
71
+ def can_flush?
72
+ !duration_below_threshold?(last_flush_finish_at || created_at, time_provider.now.utc)
65
73
  end
66
74
 
67
75
  private
68
76
 
69
77
  def duration_below_threshold?(start, finish)
70
- (finish - start) < @minimum_duration
78
+ (finish - start) < minimum_duration_seconds
71
79
  end
72
80
  end
73
81
  end