ls-trace 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (356) hide show
  1. checksums.yaml +7 -0
  2. data/.circleci/config.yml +673 -0
  3. data/.circleci/images/primary/Dockerfile-2.0.0 +73 -0
  4. data/.circleci/images/primary/Dockerfile-2.1.10 +73 -0
  5. data/.circleci/images/primary/Dockerfile-2.2.10 +73 -0
  6. data/.circleci/images/primary/Dockerfile-2.3.8 +75 -0
  7. data/.circleci/images/primary/Dockerfile-2.4.6 +73 -0
  8. data/.circleci/images/primary/Dockerfile-2.5.6 +73 -0
  9. data/.circleci/images/primary/Dockerfile-2.6.4 +73 -0
  10. data/.dockerignore +1 -0
  11. data/.env +24 -0
  12. data/.github/CODEOWNERS +1 -0
  13. data/.gitignore +59 -0
  14. data/.rspec +1 -0
  15. data/.rubocop.yml +77 -0
  16. data/.yardopts +5 -0
  17. data/Appraisals +820 -0
  18. data/CHANGELOG.md +1051 -0
  19. data/CONTRIBUTING.md +85 -0
  20. data/Gemfile +7 -0
  21. data/LICENSE +24 -0
  22. data/README.md +108 -0
  23. data/Rakefile +635 -0
  24. data/benchmarks/postgres_database.yml +9 -0
  25. data/benchmarks/sidekiq_test.rb +154 -0
  26. data/ddtrace.gemspec +63 -0
  27. data/docker-compose.yml +276 -0
  28. data/docs/DevelopmentGuide.md +195 -0
  29. data/docs/GettingStarted.md +1981 -0
  30. data/lib/ddtrace.rb +63 -0
  31. data/lib/ddtrace/analytics.rb +29 -0
  32. data/lib/ddtrace/augmentation.rb +13 -0
  33. data/lib/ddtrace/augmentation/method_wrapper.rb +20 -0
  34. data/lib/ddtrace/augmentation/method_wrapping.rb +38 -0
  35. data/lib/ddtrace/augmentation/shim.rb +102 -0
  36. data/lib/ddtrace/buffer.rb +119 -0
  37. data/lib/ddtrace/configuration.rb +30 -0
  38. data/lib/ddtrace/configuration/base.rb +82 -0
  39. data/lib/ddtrace/configuration/dependency_resolver.rb +24 -0
  40. data/lib/ddtrace/configuration/option.rb +55 -0
  41. data/lib/ddtrace/configuration/option_definition.rb +127 -0
  42. data/lib/ddtrace/configuration/option_definition_set.rb +18 -0
  43. data/lib/ddtrace/configuration/option_set.rb +6 -0
  44. data/lib/ddtrace/configuration/options.rb +107 -0
  45. data/lib/ddtrace/configuration/pin_setup.rb +30 -0
  46. data/lib/ddtrace/configuration/settings.rb +105 -0
  47. data/lib/ddtrace/context.rb +284 -0
  48. data/lib/ddtrace/context_flush.rb +132 -0
  49. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +144 -0
  50. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +37 -0
  51. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +27 -0
  52. data/lib/ddtrace/contrib/action_pack/ext.rb +16 -0
  53. data/lib/ddtrace/contrib/action_pack/integration.rb +36 -0
  54. data/lib/ddtrace/contrib/action_pack/patcher.rb +29 -0
  55. data/lib/ddtrace/contrib/action_pack/utils.rb +36 -0
  56. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +26 -0
  57. data/lib/ddtrace/contrib/action_view/ext.rb +17 -0
  58. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +78 -0
  59. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +167 -0
  60. data/lib/ddtrace/contrib/action_view/integration.rb +43 -0
  61. data/lib/ddtrace/contrib/action_view/patcher.rb +53 -0
  62. data/lib/ddtrace/contrib/action_view/utils.rb +32 -0
  63. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +25 -0
  64. data/lib/ddtrace/contrib/active_model_serializers/event.rb +65 -0
  65. data/lib/ddtrace/contrib/active_model_serializers/events.rb +30 -0
  66. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +32 -0
  67. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +35 -0
  68. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +17 -0
  69. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +39 -0
  70. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +36 -0
  71. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +46 -0
  72. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +30 -0
  73. data/lib/ddtrace/contrib/active_record/event.rb +30 -0
  74. data/lib/ddtrace/contrib/active_record/events.rb +30 -0
  75. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +57 -0
  76. data/lib/ddtrace/contrib/active_record/events/sql.rb +64 -0
  77. data/lib/ddtrace/contrib/active_record/ext.rb +21 -0
  78. data/lib/ddtrace/contrib/active_record/integration.rb +44 -0
  79. data/lib/ddtrace/contrib/active_record/patcher.rb +29 -0
  80. data/lib/ddtrace/contrib/active_record/utils.rb +76 -0
  81. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +157 -0
  82. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +62 -0
  83. data/lib/ddtrace/contrib/active_support/cache/redis.rb +47 -0
  84. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +25 -0
  85. data/lib/ddtrace/contrib/active_support/ext.rb +21 -0
  86. data/lib/ddtrace/contrib/active_support/integration.rb +38 -0
  87. data/lib/ddtrace/contrib/active_support/notifications/event.rb +62 -0
  88. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +66 -0
  89. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +159 -0
  90. data/lib/ddtrace/contrib/active_support/patcher.rb +29 -0
  91. data/lib/ddtrace/contrib/analytics.rb +20 -0
  92. data/lib/ddtrace/contrib/aws/configuration/settings.rb +25 -0
  93. data/lib/ddtrace/contrib/aws/ext.rb +20 -0
  94. data/lib/ddtrace/contrib/aws/instrumentation.rb +56 -0
  95. data/lib/ddtrace/contrib/aws/integration.rb +36 -0
  96. data/lib/ddtrace/contrib/aws/parsed_context.rb +56 -0
  97. data/lib/ddtrace/contrib/aws/patcher.rb +49 -0
  98. data/lib/ddtrace/contrib/aws/services.rb +115 -0
  99. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +15 -0
  100. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +35 -0
  101. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +11 -0
  102. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +23 -0
  103. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +32 -0
  104. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +35 -0
  105. data/lib/ddtrace/contrib/configurable.rb +59 -0
  106. data/lib/ddtrace/contrib/configuration/resolver.rb +12 -0
  107. data/lib/ddtrace/contrib/configuration/settings.rb +35 -0
  108. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +25 -0
  109. data/lib/ddtrace/contrib/dalli/ext.rb +17 -0
  110. data/lib/ddtrace/contrib/dalli/instrumentation.rb +50 -0
  111. data/lib/ddtrace/contrib/dalli/integration.rb +36 -0
  112. data/lib/ddtrace/contrib/dalli/patcher.rb +73 -0
  113. data/lib/ddtrace/contrib/dalli/quantize.rb +22 -0
  114. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +25 -0
  115. data/lib/ddtrace/contrib/delayed_job/ext.rb +18 -0
  116. data/lib/ddtrace/contrib/delayed_job/integration.rb +32 -0
  117. data/lib/ddtrace/contrib/delayed_job/patcher.rb +34 -0
  118. data/lib/ddtrace/contrib/delayed_job/plugin.rb +57 -0
  119. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +26 -0
  120. data/lib/ddtrace/contrib/elasticsearch/ext.rb +19 -0
  121. data/lib/ddtrace/contrib/elasticsearch/integration.rb +37 -0
  122. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +124 -0
  123. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +80 -0
  124. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +26 -0
  125. data/lib/ddtrace/contrib/ethon/easy_patch.rb +139 -0
  126. data/lib/ddtrace/contrib/ethon/ext.rb +15 -0
  127. data/lib/ddtrace/contrib/ethon/integration.rb +31 -0
  128. data/lib/ddtrace/contrib/ethon/multi_patch.rb +80 -0
  129. data/lib/ddtrace/contrib/ethon/patcher.rb +27 -0
  130. data/lib/ddtrace/contrib/excon/configuration/settings.rb +28 -0
  131. data/lib/ddtrace/contrib/excon/ext.rb +14 -0
  132. data/lib/ddtrace/contrib/excon/integration.rb +32 -0
  133. data/lib/ddtrace/contrib/excon/middleware.rb +154 -0
  134. data/lib/ddtrace/contrib/excon/patcher.rb +34 -0
  135. data/lib/ddtrace/contrib/extensions.rb +59 -0
  136. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +33 -0
  137. data/lib/ddtrace/contrib/faraday/ext.rb +14 -0
  138. data/lib/ddtrace/contrib/faraday/integration.rb +36 -0
  139. data/lib/ddtrace/contrib/faraday/middleware.rb +93 -0
  140. data/lib/ddtrace/contrib/faraday/patcher.rb +82 -0
  141. data/lib/ddtrace/contrib/faraday/rack_builder.rb +18 -0
  142. data/lib/ddtrace/contrib/grape/configuration/settings.rb +27 -0
  143. data/lib/ddtrace/contrib/grape/endpoint.rb +199 -0
  144. data/lib/ddtrace/contrib/grape/ext.rb +19 -0
  145. data/lib/ddtrace/contrib/grape/instrumentation.rb +33 -0
  146. data/lib/ddtrace/contrib/grape/integration.rb +36 -0
  147. data/lib/ddtrace/contrib/grape/patcher.rb +79 -0
  148. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +27 -0
  149. data/lib/ddtrace/contrib/graphql/ext.rb +13 -0
  150. data/lib/ddtrace/contrib/graphql/integration.rb +38 -0
  151. data/lib/ddtrace/contrib/graphql/patcher.rb +63 -0
  152. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +25 -0
  153. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +74 -0
  154. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +56 -0
  155. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +73 -0
  156. data/lib/ddtrace/contrib/grpc/ext.rb +15 -0
  157. data/lib/ddtrace/contrib/grpc/integration.rb +36 -0
  158. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +49 -0
  159. data/lib/ddtrace/contrib/grpc/patcher.rb +78 -0
  160. data/lib/ddtrace/contrib/http/circuit_breaker.rb +63 -0
  161. data/lib/ddtrace/contrib/http/configuration/settings.rb +26 -0
  162. data/lib/ddtrace/contrib/http/ext.rb +14 -0
  163. data/lib/ddtrace/contrib/http/instrumentation.rb +114 -0
  164. data/lib/ddtrace/contrib/http/integration.rb +32 -0
  165. data/lib/ddtrace/contrib/http/patcher.rb +32 -0
  166. data/lib/ddtrace/contrib/integration.rb +16 -0
  167. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +28 -0
  168. data/lib/ddtrace/contrib/mongodb/ext.rb +20 -0
  169. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +68 -0
  170. data/lib/ddtrace/contrib/mongodb/integration.rb +36 -0
  171. data/lib/ddtrace/contrib/mongodb/parsers.rb +68 -0
  172. data/lib/ddtrace/contrib/mongodb/patcher.rb +37 -0
  173. data/lib/ddtrace/contrib/mongodb/subscribers.rb +108 -0
  174. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +25 -0
  175. data/lib/ddtrace/contrib/mysql2/ext.rb +15 -0
  176. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +60 -0
  177. data/lib/ddtrace/contrib/mysql2/integration.rb +32 -0
  178. data/lib/ddtrace/contrib/mysql2/patcher.rb +33 -0
  179. data/lib/ddtrace/contrib/patchable.rb +42 -0
  180. data/lib/ddtrace/contrib/patcher.rb +28 -0
  181. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +25 -0
  182. data/lib/ddtrace/contrib/racecar/event.rb +67 -0
  183. data/lib/ddtrace/contrib/racecar/events.rb +30 -0
  184. data/lib/ddtrace/contrib/racecar/events/batch.rb +27 -0
  185. data/lib/ddtrace/contrib/racecar/events/message.rb +27 -0
  186. data/lib/ddtrace/contrib/racecar/ext.rb +21 -0
  187. data/lib/ddtrace/contrib/racecar/integration.rb +36 -0
  188. data/lib/ddtrace/contrib/racecar/patcher.rb +32 -0
  189. data/lib/ddtrace/contrib/rack/configuration/settings.rb +41 -0
  190. data/lib/ddtrace/contrib/rack/ext.rb +18 -0
  191. data/lib/ddtrace/contrib/rack/integration.rb +32 -0
  192. data/lib/ddtrace/contrib/rack/middlewares.rb +283 -0
  193. data/lib/ddtrace/contrib/rack/patcher.rb +72 -0
  194. data/lib/ddtrace/contrib/rack/request_queue.rb +39 -0
  195. data/lib/ddtrace/contrib/rails/configuration/settings.rb +80 -0
  196. data/lib/ddtrace/contrib/rails/ext.rb +12 -0
  197. data/lib/ddtrace/contrib/rails/framework.rb +100 -0
  198. data/lib/ddtrace/contrib/rails/integration.rb +37 -0
  199. data/lib/ddtrace/contrib/rails/middlewares.rb +38 -0
  200. data/lib/ddtrace/contrib/rails/patcher.rb +78 -0
  201. data/lib/ddtrace/contrib/rails/railtie.rb +17 -0
  202. data/lib/ddtrace/contrib/rails/utils.rb +20 -0
  203. data/lib/ddtrace/contrib/rake/configuration/settings.rb +27 -0
  204. data/lib/ddtrace/contrib/rake/ext.rb +18 -0
  205. data/lib/ddtrace/contrib/rake/instrumentation.rb +84 -0
  206. data/lib/ddtrace/contrib/rake/integration.rb +32 -0
  207. data/lib/ddtrace/contrib/rake/patcher.rb +36 -0
  208. data/lib/ddtrace/contrib/redis/configuration/settings.rb +25 -0
  209. data/lib/ddtrace/contrib/redis/ext.rb +18 -0
  210. data/lib/ddtrace/contrib/redis/integration.rb +36 -0
  211. data/lib/ddtrace/contrib/redis/patcher.rb +94 -0
  212. data/lib/ddtrace/contrib/redis/quantize.rb +47 -0
  213. data/lib/ddtrace/contrib/redis/tags.rb +38 -0
  214. data/lib/ddtrace/contrib/registerable.rb +33 -0
  215. data/lib/ddtrace/contrib/registry.rb +42 -0
  216. data/lib/ddtrace/contrib/resque/configuration/settings.rb +26 -0
  217. data/lib/ddtrace/contrib/resque/ext.rb +14 -0
  218. data/lib/ddtrace/contrib/resque/integration.rb +37 -0
  219. data/lib/ddtrace/contrib/resque/patcher.rb +35 -0
  220. data/lib/ddtrace/contrib/resque/resque_job.rb +76 -0
  221. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +26 -0
  222. data/lib/ddtrace/contrib/rest_client/ext.rb +14 -0
  223. data/lib/ddtrace/contrib/rest_client/integration.rb +31 -0
  224. data/lib/ddtrace/contrib/rest_client/patcher.rb +25 -0
  225. data/lib/ddtrace/contrib/rest_client/request_patch.rb +89 -0
  226. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +23 -0
  227. data/lib/ddtrace/contrib/sequel/database.rb +61 -0
  228. data/lib/ddtrace/contrib/sequel/dataset.rb +62 -0
  229. data/lib/ddtrace/contrib/sequel/ext.rb +15 -0
  230. data/lib/ddtrace/contrib/sequel/integration.rb +32 -0
  231. data/lib/ddtrace/contrib/sequel/patcher.rb +39 -0
  232. data/lib/ddtrace/contrib/sequel/utils.rb +46 -0
  233. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +24 -0
  234. data/lib/ddtrace/contrib/shoryuken/ext.rb +18 -0
  235. data/lib/ddtrace/contrib/shoryuken/integration.rb +35 -0
  236. data/lib/ddtrace/contrib/shoryuken/patcher.rb +30 -0
  237. data/lib/ddtrace/contrib/shoryuken/tracer.rb +45 -0
  238. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +43 -0
  239. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +26 -0
  240. data/lib/ddtrace/contrib/sidekiq/ext.rb +21 -0
  241. data/lib/ddtrace/contrib/sidekiq/integration.rb +36 -0
  242. data/lib/ddtrace/contrib/sidekiq/patcher.rb +40 -0
  243. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +58 -0
  244. data/lib/ddtrace/contrib/sidekiq/tracing.rb +28 -0
  245. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +34 -0
  246. data/lib/ddtrace/contrib/sinatra/env.rb +38 -0
  247. data/lib/ddtrace/contrib/sinatra/ext.rb +18 -0
  248. data/lib/ddtrace/contrib/sinatra/headers.rb +31 -0
  249. data/lib/ddtrace/contrib/sinatra/integration.rb +36 -0
  250. data/lib/ddtrace/contrib/sinatra/patcher.rb +33 -0
  251. data/lib/ddtrace/contrib/sinatra/tracer.rb +84 -0
  252. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +72 -0
  253. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +25 -0
  254. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +26 -0
  255. data/lib/ddtrace/contrib/sucker_punch/ext.rb +18 -0
  256. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +70 -0
  257. data/lib/ddtrace/contrib/sucker_punch/integration.rb +36 -0
  258. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +48 -0
  259. data/lib/ddtrace/correlation.rb +28 -0
  260. data/lib/ddtrace/diagnostics/health.rb +30 -0
  261. data/lib/ddtrace/distributed_tracing/headers/b3.rb +44 -0
  262. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +56 -0
  263. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +42 -0
  264. data/lib/ddtrace/distributed_tracing/headers/headers.rb +70 -0
  265. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +45 -0
  266. data/lib/ddtrace/encoding.rb +65 -0
  267. data/lib/ddtrace/environment.rb +23 -0
  268. data/lib/ddtrace/error.rb +27 -0
  269. data/lib/ddtrace/ext/analytics.rb +11 -0
  270. data/lib/ddtrace/ext/app_types.rb +11 -0
  271. data/lib/ddtrace/ext/diagnostics.rb +25 -0
  272. data/lib/ddtrace/ext/distributed.rb +33 -0
  273. data/lib/ddtrace/ext/errors.rb +10 -0
  274. data/lib/ddtrace/ext/forced_tracing.rb +25 -0
  275. data/lib/ddtrace/ext/http.rb +46 -0
  276. data/lib/ddtrace/ext/manual_tracing.rb +9 -0
  277. data/lib/ddtrace/ext/metrics.rb +15 -0
  278. data/lib/ddtrace/ext/net.rb +10 -0
  279. data/lib/ddtrace/ext/priority.rb +16 -0
  280. data/lib/ddtrace/ext/runtime.rb +26 -0
  281. data/lib/ddtrace/ext/sql.rb +8 -0
  282. data/lib/ddtrace/ext/transport.rb +17 -0
  283. data/lib/ddtrace/forced_tracing.rb +36 -0
  284. data/lib/ddtrace/logger.rb +39 -0
  285. data/lib/ddtrace/metrics.rb +215 -0
  286. data/lib/ddtrace/monkey.rb +58 -0
  287. data/lib/ddtrace/opentracer.rb +40 -0
  288. data/lib/ddtrace/opentracer/binary_propagator.rb +24 -0
  289. data/lib/ddtrace/opentracer/carrier.rb +6 -0
  290. data/lib/ddtrace/opentracer/distributed_headers.rb +52 -0
  291. data/lib/ddtrace/opentracer/global_tracer.rb +15 -0
  292. data/lib/ddtrace/opentracer/propagator.rb +22 -0
  293. data/lib/ddtrace/opentracer/rack_propagator.rb +60 -0
  294. data/lib/ddtrace/opentracer/scope.rb +15 -0
  295. data/lib/ddtrace/opentracer/scope_manager.rb +6 -0
  296. data/lib/ddtrace/opentracer/span.rb +98 -0
  297. data/lib/ddtrace/opentracer/span_context.rb +14 -0
  298. data/lib/ddtrace/opentracer/span_context_factory.rb +23 -0
  299. data/lib/ddtrace/opentracer/text_map_propagator.rb +75 -0
  300. data/lib/ddtrace/opentracer/thread_local_scope.rb +30 -0
  301. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +40 -0
  302. data/lib/ddtrace/opentracer/tracer.rb +208 -0
  303. data/lib/ddtrace/patcher.rb +47 -0
  304. data/lib/ddtrace/pin.rb +114 -0
  305. data/lib/ddtrace/pipeline.rb +46 -0
  306. data/lib/ddtrace/pipeline/span_filter.rb +38 -0
  307. data/lib/ddtrace/pipeline/span_processor.rb +20 -0
  308. data/lib/ddtrace/propagation/grpc_propagator.rb +61 -0
  309. data/lib/ddtrace/propagation/http_propagator.rb +75 -0
  310. data/lib/ddtrace/provider.rb +21 -0
  311. data/lib/ddtrace/quantization/hash.rb +103 -0
  312. data/lib/ddtrace/quantization/http.rb +86 -0
  313. data/lib/ddtrace/runtime/cgroup.rb +44 -0
  314. data/lib/ddtrace/runtime/class_count.rb +17 -0
  315. data/lib/ddtrace/runtime/container.rb +73 -0
  316. data/lib/ddtrace/runtime/gc.rb +16 -0
  317. data/lib/ddtrace/runtime/identity.rb +41 -0
  318. data/lib/ddtrace/runtime/metrics.rb +93 -0
  319. data/lib/ddtrace/runtime/object_space.rb +19 -0
  320. data/lib/ddtrace/runtime/socket.rb +14 -0
  321. data/lib/ddtrace/runtime/thread_count.rb +16 -0
  322. data/lib/ddtrace/sampler.rb +195 -0
  323. data/lib/ddtrace/span.rb +260 -0
  324. data/lib/ddtrace/sync_writer.rb +62 -0
  325. data/lib/ddtrace/tracer.rb +459 -0
  326. data/lib/ddtrace/transport/http.rb +91 -0
  327. data/lib/ddtrace/transport/http/adapters/net.rb +112 -0
  328. data/lib/ddtrace/transport/http/adapters/registry.rb +24 -0
  329. data/lib/ddtrace/transport/http/adapters/test.rb +77 -0
  330. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +64 -0
  331. data/lib/ddtrace/transport/http/api.rb +46 -0
  332. data/lib/ddtrace/transport/http/api/endpoint.rb +27 -0
  333. data/lib/ddtrace/transport/http/api/fallbacks.rb +22 -0
  334. data/lib/ddtrace/transport/http/api/instance.rb +29 -0
  335. data/lib/ddtrace/transport/http/api/map.rb +14 -0
  336. data/lib/ddtrace/transport/http/api/spec.rb +15 -0
  337. data/lib/ddtrace/transport/http/builder.rb +165 -0
  338. data/lib/ddtrace/transport/http/client.rb +107 -0
  339. data/lib/ddtrace/transport/http/env.rb +48 -0
  340. data/lib/ddtrace/transport/http/response.rb +26 -0
  341. data/lib/ddtrace/transport/http/statistics.rb +30 -0
  342. data/lib/ddtrace/transport/http/traces.rb +140 -0
  343. data/lib/ddtrace/transport/parcel.rb +13 -0
  344. data/lib/ddtrace/transport/request.rb +13 -0
  345. data/lib/ddtrace/transport/response.rb +49 -0
  346. data/lib/ddtrace/transport/statistics.rb +72 -0
  347. data/lib/ddtrace/transport/traces.rb +33 -0
  348. data/lib/ddtrace/utils.rb +65 -0
  349. data/lib/ddtrace/utils/database.rb +25 -0
  350. data/lib/ddtrace/utils/time.rb +14 -0
  351. data/lib/ddtrace/vendor/active_record/connection_specification.rb +301 -0
  352. data/lib/ddtrace/version.rb +12 -0
  353. data/lib/ddtrace/workers.rb +125 -0
  354. data/lib/ddtrace/writer.rb +157 -0
  355. data/tasks/release_gem.rake +28 -0
  356. metadata +682 -0
@@ -0,0 +1,30 @@
1
+ require 'ddtrace/contrib/configuration/settings'
2
+ require 'ddtrace/contrib/active_record/ext'
3
+ require 'ddtrace/contrib/active_record/utils'
4
+
5
+ module Datadog
6
+ module Contrib
7
+ module ActiveRecord
8
+ module Configuration
9
+ # Custom settings for the ActiveRecord integration
10
+ class Settings < Contrib::Configuration::Settings
11
+ option :analytics_enabled do |o|
12
+ o.default { env_to_bool(Ext::ENV_ANALYTICS_ENABLED, false) }
13
+ o.lazy
14
+ end
15
+
16
+ option :analytics_sample_rate do |o|
17
+ o.default { env_to_float(Ext::ENV_ANALYTICS_SAMPLE_RATE, 1.0) }
18
+ o.lazy
19
+ end
20
+
21
+ option :orm_service_name
22
+ option :service_name do |o|
23
+ o.default { Utils.adapter_name }
24
+ o.lazy
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,30 @@
1
+ require 'ddtrace/contrib/active_support/notifications/event'
2
+
3
+ module Datadog
4
+ module Contrib
5
+ module ActiveRecord
6
+ # Defines basic behaviors for an ActiveRecord event.
7
+ module Event
8
+ def self.included(base)
9
+ base.send(:include, ActiveSupport::Notifications::Event)
10
+ base.send(:extend, ClassMethods)
11
+ end
12
+
13
+ # Class methods for ActiveRecord events.
14
+ module ClassMethods
15
+ def span_options
16
+ { service: configuration[:service_name] }
17
+ end
18
+
19
+ def tracer
20
+ -> { configuration[:tracer] }
21
+ end
22
+
23
+ def configuration
24
+ Datadog.configuration[:active_record]
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,30 @@
1
+ require 'ddtrace/contrib/active_record/events/instantiation'
2
+ require 'ddtrace/contrib/active_record/events/sql'
3
+
4
+ module Datadog
5
+ module Contrib
6
+ module ActiveRecord
7
+ # Defines collection of instrumented ActiveRecord events
8
+ module Events
9
+ ALL = [
10
+ Events::Instantiation,
11
+ Events::SQL
12
+ ].freeze
13
+
14
+ module_function
15
+
16
+ def all
17
+ self::ALL
18
+ end
19
+
20
+ def subscriptions
21
+ all.collect(&:subscriptions).collect(&:to_a).flatten
22
+ end
23
+
24
+ def subscribe!
25
+ all.each(&:subscribe!)
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,57 @@
1
+ require 'ddtrace/contrib/analytics'
2
+ require 'ddtrace/contrib/active_record/ext'
3
+ require 'ddtrace/contrib/active_record/event'
4
+
5
+ module Datadog
6
+ module Contrib
7
+ module ActiveRecord
8
+ module Events
9
+ # Defines instrumentation for instantiation.active_record event
10
+ module Instantiation
11
+ include ActiveRecord::Event
12
+
13
+ EVENT_NAME = 'instantiation.active_record'.freeze
14
+
15
+ module_function
16
+
17
+ def supported?
18
+ Gem.loaded_specs['activerecord'] \
19
+ && Gem.loaded_specs['activerecord'].version >= Gem::Version.new('4.2')
20
+ end
21
+
22
+ def event_name
23
+ self::EVENT_NAME
24
+ end
25
+
26
+ def span_name
27
+ Ext::SPAN_INSTANTIATION
28
+ end
29
+
30
+ def process(span, event, _id, payload)
31
+ # Inherit service name from parent, if available.
32
+ span.service = if configuration[:orm_service_name]
33
+ configuration[:orm_service_name]
34
+ elsif span.parent
35
+ span.parent.service
36
+ else
37
+ Ext::SERVICE_NAME
38
+ end
39
+
40
+ span.resource = payload.fetch(:class_name)
41
+ span.span_type = Ext::SPAN_TYPE_INSTANTIATION
42
+
43
+ # Set analytics sample rate
44
+ if Contrib::Analytics.enabled?(configuration[:analytics_enabled])
45
+ Contrib::Analytics.set_sample_rate(span, configuration[:analytics_sample_rate])
46
+ end
47
+
48
+ span.set_tag(Ext::TAG_INSTANTIATION_CLASS_NAME, payload.fetch(:class_name))
49
+ span.set_tag(Ext::TAG_INSTANTIATION_RECORD_COUNT, payload.fetch(:record_count))
50
+ rescue StandardError => e
51
+ Datadog::Tracer.log.debug(e.message)
52
+ end
53
+ end
54
+ end
55
+ end
56
+ end
57
+ end
@@ -0,0 +1,64 @@
1
+ require 'ddtrace/ext/net'
2
+ require 'ddtrace/contrib/analytics'
3
+ require 'ddtrace/contrib/active_record/ext'
4
+ require 'ddtrace/contrib/active_record/event'
5
+
6
+ module Datadog
7
+ module Contrib
8
+ module ActiveRecord
9
+ module Events
10
+ # Defines instrumentation for sql.active_record event
11
+ module SQL
12
+ include ActiveRecord::Event
13
+
14
+ EVENT_NAME = 'sql.active_record'.freeze
15
+ PAYLOAD_CACHE = 'CACHE'.freeze
16
+
17
+ module_function
18
+
19
+ def event_name
20
+ self::EVENT_NAME
21
+ end
22
+
23
+ def span_name
24
+ Ext::SPAN_SQL
25
+ end
26
+
27
+ def process(span, event, _id, payload)
28
+ config = Utils.connection_config(payload[:connection], payload[:connection_id])
29
+ settings = Datadog.configuration[:active_record, config]
30
+ adapter_name = Datadog::Utils::Database.normalize_vendor(config[:adapter])
31
+ service_name = if settings.service_name != Datadog::Utils::Database::VENDOR_DEFAULT
32
+ settings.service_name
33
+ else
34
+ adapter_name
35
+ end
36
+
37
+ span.name = "#{adapter_name}.query"
38
+ span.service = service_name
39
+ span.resource = payload.fetch(:sql)
40
+ span.span_type = Datadog::Ext::SQL::TYPE
41
+
42
+ # Set analytics sample rate
43
+ if Contrib::Analytics.enabled?(configuration[:analytics_enabled])
44
+ Contrib::Analytics.set_sample_rate(span, configuration[:analytics_sample_rate])
45
+ end
46
+
47
+ # Find out if the SQL query has been cached in this request. This meta is really
48
+ # helpful to users because some spans may have 0ns of duration because the query
49
+ # is simply cached from memory, so the notification is fired with start == finish.
50
+ cached = payload[:cached] || (payload[:name] == PAYLOAD_CACHE)
51
+
52
+ span.set_tag(Ext::TAG_DB_VENDOR, adapter_name)
53
+ span.set_tag(Ext::TAG_DB_NAME, config[:database])
54
+ span.set_tag(Ext::TAG_DB_CACHED, cached) if cached
55
+ span.set_tag(Datadog::Ext::NET::TARGET_HOST, config[:host]) if config[:host]
56
+ span.set_tag(Datadog::Ext::NET::TARGET_PORT, config[:port]) if config[:port]
57
+ rescue StandardError => e
58
+ Datadog::Tracer.log.debug(e.message)
59
+ end
60
+ end
61
+ end
62
+ end
63
+ end
64
+ end
@@ -0,0 +1,21 @@
1
+ module Datadog
2
+ module Contrib
3
+ module ActiveRecord
4
+ # ActiveRecord integration constants
5
+ module Ext
6
+ APP = 'active_record'.freeze
7
+ ENV_ANALYTICS_ENABLED = 'DD_ACTIVE_RECORD_ANALYTICS_ENABLED'.freeze
8
+ ENV_ANALYTICS_SAMPLE_RATE = 'DD_ACTIVE_RECORD_ANALYTICS_SAMPLE_RATE'.freeze
9
+ SERVICE_NAME = 'active_record'.freeze
10
+ SPAN_INSTANTIATION = 'active_record.instantiation'.freeze
11
+ SPAN_SQL = 'active_record.sql'.freeze
12
+ SPAN_TYPE_INSTANTIATION = 'custom'.freeze
13
+ TAG_DB_CACHED = 'active_record.db.cached'.freeze
14
+ TAG_DB_NAME = 'active_record.db.name'.freeze
15
+ TAG_DB_VENDOR = 'active_record.db.vendor'.freeze
16
+ TAG_INSTANTIATION_CLASS_NAME = 'active_record.instantiation.class_name'.freeze
17
+ TAG_INSTANTIATION_RECORD_COUNT = 'active_record.instantiation.record_count'.freeze
18
+ end
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,44 @@
1
+ require 'ddtrace/ext/sql'
2
+ require 'ddtrace/ext/app_types'
3
+ require 'ddtrace/contrib/integration'
4
+ require 'ddtrace/contrib/active_record/events'
5
+ require 'ddtrace/contrib/active_record/configuration/resolver'
6
+ require 'ddtrace/contrib/active_record/configuration/settings'
7
+ require 'ddtrace/contrib/active_record/patcher'
8
+
9
+ module Datadog
10
+ module Contrib
11
+ module ActiveRecord
12
+ # Describes the ActiveRecord integration
13
+ class Integration
14
+ include Contrib::Integration
15
+
16
+ register_as :active_record, auto_patch: false
17
+
18
+ def self.version
19
+ Gem.loaded_specs['activerecord'] && Gem.loaded_specs['activerecord'].version
20
+ end
21
+
22
+ def self.present?
23
+ super && defined?(::ActiveRecord)
24
+ end
25
+
26
+ def self.compatible?
27
+ super && version >= Gem::Version.new('3.0')
28
+ end
29
+
30
+ def default_configuration
31
+ Configuration::Settings.new
32
+ end
33
+
34
+ def patcher
35
+ ActiveRecord::Patcher
36
+ end
37
+
38
+ def resolver
39
+ @resolver ||= Configuration::Resolver.new
40
+ end
41
+ end
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,29 @@
1
+ require 'ddtrace/contrib/patcher'
2
+ require 'ddtrace/contrib/active_record/events'
3
+
4
+ module Datadog
5
+ module Contrib
6
+ module ActiveRecord
7
+ # Patcher enables patching of 'active_record' module.
8
+ module Patcher
9
+ include Contrib::Patcher
10
+
11
+ module_function
12
+
13
+ def patched?
14
+ done?(:active_record)
15
+ end
16
+
17
+ def patch
18
+ do_once(:active_record) do
19
+ begin
20
+ Events.subscribe!
21
+ rescue StandardError => e
22
+ Datadog::Tracer.log.error("Unable to apply Active Record integration: #{e}")
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,76 @@
1
+ module Datadog
2
+ module Contrib
3
+ module ActiveRecord
4
+ # Common utilities for Rails
5
+ module Utils
6
+ EMPTY_CONFIG = {}.freeze
7
+
8
+ def self.adapter_name
9
+ Datadog::Utils::Database.normalize_vendor(connection_config[:adapter])
10
+ end
11
+
12
+ def self.database_name
13
+ connection_config[:database]
14
+ end
15
+
16
+ def self.adapter_host
17
+ connection_config[:host]
18
+ end
19
+
20
+ def self.adapter_port
21
+ connection_config[:port]
22
+ end
23
+
24
+ # In newer Rails versions, the `payload` contains both the `connection` and its `object_id` named `connection_id`.
25
+ #
26
+ # So, if rails is recent we'll have a direct access to the connection.
27
+ # Else, we'll find it thanks to the passed `connection_id`.
28
+ #
29
+ # See this PR for more details: https://github.com/rails/rails/pull/34602
30
+ #
31
+ def self.connection_config(connection = nil, connection_id = nil)
32
+ return default_connection_config if connection.nil? && connection_id.nil?
33
+
34
+ conn = if !connection.nil?
35
+ connection
36
+ # Rails 3.0 - 3.2
37
+ elsif Gem.loaded_specs['activerecord'].version < Gem::Version.new('4.0')
38
+ ::ActiveRecord::Base
39
+ .connection_handler
40
+ .connection_pools
41
+ .values
42
+ .flat_map(&:connections)
43
+ .find { |c| c.object_id == connection_id }
44
+ # Rails 4.2+
45
+ else
46
+ ::ActiveRecord::Base
47
+ .connection_handler
48
+ .connection_pool_list
49
+ .flat_map(&:connections)
50
+ .find { |c| c.object_id == connection_id }
51
+ end
52
+
53
+ if conn.instance_variable_defined?(:@config)
54
+ conn.instance_variable_get(:@config)
55
+ else
56
+ EMPTY_CONFIG
57
+ end
58
+ end
59
+
60
+ def self.default_connection_config
61
+ return @default_connection_config if instance_variable_defined?(:@default_connection_config)
62
+ current_connection_name = if ::ActiveRecord::Base.respond_to?(:connection_specification_name)
63
+ ::ActiveRecord::Base.connection_specification_name
64
+ else
65
+ ::ActiveRecord::Base
66
+ end
67
+
68
+ connection_pool = ::ActiveRecord::Base.connection_handler.retrieve_connection_pool(current_connection_name)
69
+ connection_pool.nil? ? EMPTY_CONFIG : (@default_connection_config = connection_pool.spec.config)
70
+ rescue StandardError
71
+ EMPTY_CONFIG
72
+ end
73
+ end
74
+ end
75
+ end
76
+ end
@@ -0,0 +1,157 @@
1
+ require 'ddtrace/contrib/active_support/ext'
2
+
3
+ module Datadog
4
+ module Contrib
5
+ module ActiveSupport
6
+ module Cache
7
+ # Defines instrumentation for ActiveSupport caching
8
+ # rubocop:disable Lint/RescueException
9
+ module Instrumentation
10
+ module_function
11
+
12
+ def start_trace_cache(payload)
13
+ tracer = Datadog.configuration[:active_support][:tracer]
14
+
15
+ # In most of the cases Rails ``fetch()`` and ``read()`` calls are nested.
16
+ # This check ensures that two reads are not nested since they don't provide
17
+ # interesting details.
18
+ # NOTE: the ``finish_trace_cache()`` is fired but it already has a safe-guard
19
+ # to avoid any kind of issue.
20
+ current_span = tracer.active_span
21
+ return if payload[:action] == Ext::RESOURCE_CACHE_GET &&
22
+ current_span.try(:name) == Ext::SPAN_CACHE &&
23
+ current_span.try(:resource) == Ext::RESOURCE_CACHE_GET
24
+
25
+ tracing_context = payload.fetch(:tracing_context)
26
+
27
+ # create a new ``Span`` and add it to the tracing context
28
+ service = Datadog.configuration[:active_support][:cache_service]
29
+ type = Ext::SPAN_TYPE_CACHE
30
+ span = tracer.trace(Ext::SPAN_CACHE, service: service, span_type: type)
31
+ span.resource = payload.fetch(:action)
32
+ tracing_context[:dd_cache_span] = span
33
+ rescue StandardError => e
34
+ Datadog::Tracer.log.debug(e.message)
35
+ end
36
+
37
+ def finish_trace_cache(payload)
38
+ # retrieve the tracing context and continue the trace
39
+ tracing_context = payload.fetch(:tracing_context)
40
+ span = tracing_context[:dd_cache_span]
41
+ return unless span && !span.finished?
42
+
43
+ begin
44
+ # discard parameters from the cache_store configuration
45
+ if defined?(::Rails)
46
+ store, = *Array.wrap(::Rails.configuration.cache_store).flatten
47
+ span.set_tag(Ext::TAG_CACHE_BACKEND, store)
48
+ end
49
+
50
+ normalized_key = ::ActiveSupport::Cache.expand_cache_key(payload.fetch(:key))
51
+ cache_key = Datadog::Utils.truncate(normalized_key, Ext::QUANTIZE_CACHE_MAX_KEY_SIZE)
52
+ span.set_tag(Ext::TAG_CACHE_KEY, cache_key)
53
+
54
+ span.set_error(payload[:exception]) if payload[:exception]
55
+ ensure
56
+ span.finish
57
+ end
58
+ rescue StandardError => e
59
+ Datadog::Tracer.log.debug(e.message)
60
+ end
61
+
62
+ # Defines instrumentation for ActiveSupport cache reading
63
+ module Read
64
+ def read(*args, &block)
65
+ payload = {
66
+ action: Ext::RESOURCE_CACHE_GET,
67
+ key: args[0],
68
+ tracing_context: {}
69
+ }
70
+
71
+ begin
72
+ # process and catch cache exceptions
73
+ Instrumentation.start_trace_cache(payload)
74
+ super
75
+ rescue Exception => e
76
+ payload[:exception] = [e.class.name, e.message]
77
+ payload[:exception_object] = e
78
+ raise e
79
+ end
80
+ ensure
81
+ Instrumentation.finish_trace_cache(payload)
82
+ end
83
+ end
84
+
85
+ # Defines instrumentation for ActiveSupport cache fetching
86
+ module Fetch
87
+ def fetch(*args, &block)
88
+ payload = {
89
+ action: Ext::RESOURCE_CACHE_GET,
90
+ key: args[0],
91
+ tracing_context: {}
92
+ }
93
+
94
+ begin
95
+ # process and catch cache exceptions
96
+ Instrumentation.start_trace_cache(payload)
97
+ super
98
+ rescue Exception => e
99
+ payload[:exception] = [e.class.name, e.message]
100
+ payload[:exception_object] = e
101
+ raise e
102
+ end
103
+ ensure
104
+ Instrumentation.finish_trace_cache(payload)
105
+ end
106
+ end
107
+
108
+ # Defines instrumentation for ActiveSupport cache writing
109
+ module Write
110
+ def write(*args, &block)
111
+ payload = {
112
+ action: Ext::RESOURCE_CACHE_SET,
113
+ key: args[0],
114
+ tracing_context: {}
115
+ }
116
+
117
+ begin
118
+ # process and catch cache exceptions
119
+ Instrumentation.start_trace_cache(payload)
120
+ super
121
+ rescue Exception => e
122
+ payload[:exception] = [e.class.name, e.message]
123
+ payload[:exception_object] = e
124
+ raise e
125
+ end
126
+ ensure
127
+ Instrumentation.finish_trace_cache(payload)
128
+ end
129
+ end
130
+
131
+ # Defines instrumentation for ActiveSupport cache deleting
132
+ module Delete
133
+ def delete(*args, &block)
134
+ payload = {
135
+ action: Ext::RESOURCE_CACHE_DELETE,
136
+ key: args[0],
137
+ tracing_context: {}
138
+ }
139
+
140
+ begin
141
+ # process and catch cache exceptions
142
+ Instrumentation.start_trace_cache(payload)
143
+ super
144
+ rescue Exception => e
145
+ payload[:exception] = [e.class.name, e.message]
146
+ payload[:exception_object] = e
147
+ raise e
148
+ end
149
+ ensure
150
+ Instrumentation.finish_trace_cache(payload)
151
+ end
152
+ end
153
+ end
154
+ end
155
+ end
156
+ end
157
+ end