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,44 @@
1
+ require 'ddtrace/ext/distributed'
2
+ require 'ddtrace/distributed_tracing/headers/headers'
3
+ require 'ddtrace/distributed_tracing/headers/helpers'
4
+
5
+ module Datadog
6
+ module DistributedTracing
7
+ module Headers
8
+ # B3 provides helpers to inject or extract headers for B3 style headers
9
+ module B3
10
+ include Ext::DistributedTracing
11
+
12
+ def self.inject!(context, env)
13
+ return if context.nil?
14
+
15
+ # DEV: We need these to be hex encoded
16
+ env[B3_HEADER_TRACE_ID] = context.trace_id.to_s(16)
17
+ env[B3_HEADER_SPAN_ID] = context.span_id.to_s(16)
18
+
19
+ unless context.sampling_priority.nil?
20
+ sampling_priority = DistributedTracing::Headers::Helpers.clamp_sampling_priority(context.sampling_priority)
21
+ env[B3_HEADER_SAMPLED] = sampling_priority.to_s
22
+ end
23
+ end
24
+
25
+ def self.extract(env)
26
+ # Extract values from headers
27
+ # DEV: B3 doesn't have "origin"
28
+ headers = Headers.new(env)
29
+ trace_id = headers.id(B3_HEADER_TRACE_ID, 16)
30
+ span_id = headers.id(B3_HEADER_SPAN_ID, 16)
31
+ # We don't need to try and convert sampled since B3 supports 0/1 (AUTO_REJECT/AUTO_KEEP)
32
+ sampling_priority = headers.number(B3_HEADER_SAMPLED)
33
+
34
+ # Return early if this propagation is not valid
35
+ return unless trace_id && span_id
36
+
37
+ ::Datadog::Context.new(trace_id: trace_id,
38
+ span_id: span_id,
39
+ sampling_priority: sampling_priority)
40
+ end
41
+ end
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,56 @@
1
+ require 'ddtrace/ext/distributed'
2
+ require 'ddtrace/distributed_tracing/headers/headers'
3
+ require 'ddtrace/distributed_tracing/headers/helpers'
4
+
5
+ module Datadog
6
+ module DistributedTracing
7
+ module Headers
8
+ # B3Single provides helpers to inject or extract headers for B3 single header style headers
9
+ module B3Single
10
+ include Ext::DistributedTracing
11
+
12
+ def self.inject!(context, env)
13
+ return if context.nil?
14
+
15
+ # Header format:
16
+ # b3: {TraceId}-{SpanId}-{SamplingState}-{ParentSpanId}
17
+ # https://github.com/apache/incubator-zipkin-b3-propagation/tree/7c6e9f14d6627832bd80baa87ac7dabee7be23cf#single-header
18
+ # DEV: `{SamplingState}` and `{ParentSpanId`}` are optional
19
+
20
+ # DEV: We need these to be hex encoded
21
+ header = "#{context.trace_id.to_s(16)}-#{context.span_id.to_s(16)}"
22
+
23
+ unless context.sampling_priority.nil?
24
+ sampling_priority = DistributedTracing::Headers::Helpers.clamp_sampling_priority(context.sampling_priority)
25
+ header += "-#{sampling_priority}"
26
+ end
27
+
28
+ env[B3_HEADER_SINGLE] = header
29
+ end
30
+
31
+ def self.extract(env)
32
+ # Header format:
33
+ # b3: {TraceId}-{SpanId}-{SamplingState}-{ParentSpanId}
34
+ # https://github.com/apache/incubator-zipkin-b3-propagation/tree/7c6e9f14d6627832bd80baa87ac7dabee7be23cf#single-header
35
+ # DEV: `{SamplingState}` and `{ParentSpanId`}` are optional
36
+
37
+ headers = Headers.new(env)
38
+ value = headers.header(B3_HEADER_SINGLE)
39
+ return if value.nil?
40
+
41
+ parts = value.split('-')
42
+ trace_id = headers.value_to_id(parts[0], 16) unless parts.empty?
43
+ span_id = headers.value_to_id(parts[1], 16) if parts.length > 1
44
+ sampling_priority = headers.value_to_number(parts[2]) if parts.length > 2
45
+
46
+ # Return early if this propagation is not valid
47
+ return unless trace_id && span_id
48
+
49
+ ::Datadog::Context.new(trace_id: trace_id,
50
+ span_id: span_id,
51
+ sampling_priority: sampling_priority)
52
+ end
53
+ end
54
+ end
55
+ end
56
+ end
@@ -0,0 +1,42 @@
1
+ require 'ddtrace/ext/distributed'
2
+ require 'ddtrace/distributed_tracing/headers/headers'
3
+
4
+ module Datadog
5
+ module DistributedTracing
6
+ module Headers
7
+ # Datadog provides helpers to inject or extract headers for Datadog style headers
8
+ module Datadog
9
+ include Ext::DistributedTracing
10
+
11
+ def self.inject!(context, env)
12
+ return if context.nil?
13
+
14
+ env[HTTP_HEADER_TRACE_ID] = context.trace_id.to_s
15
+ env[HTTP_HEADER_PARENT_ID] = context.span_id.to_s
16
+ env[HTTP_HEADER_SAMPLING_PRIORITY] = context.sampling_priority.to_s unless context.sampling_priority.nil?
17
+ env[HTTP_HEADER_ORIGIN] = context.origin.to_s unless context.origin.nil?
18
+ end
19
+
20
+ def self.extract(env)
21
+ # Extract values from headers
22
+ headers = Headers.new(env)
23
+ trace_id = headers.id(HTTP_HEADER_TRACE_ID)
24
+ parent_id = headers.id(HTTP_HEADER_PARENT_ID)
25
+ origin = headers.header(HTTP_HEADER_ORIGIN)
26
+ sampling_priority = headers.number(HTTP_HEADER_SAMPLING_PRIORITY)
27
+
28
+ # Return early if this propagation is not valid
29
+ # DEV: To be valid we need to have a trace id and a parent id or when it is a synthetics trace, just the trace id
30
+ # DEV: `DistributedHeaders#id` will not return 0
31
+ return unless (trace_id && parent_id) || (origin && trace_id)
32
+
33
+ # Return new context
34
+ ::Datadog::Context.new(trace_id: trace_id,
35
+ span_id: parent_id,
36
+ origin: origin,
37
+ sampling_priority: sampling_priority)
38
+ end
39
+ end
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,70 @@
1
+ require 'ddtrace/configuration'
2
+ require 'ddtrace/span'
3
+ require 'ddtrace/ext/distributed'
4
+
5
+ module Datadog
6
+ module DistributedTracing
7
+ module Headers
8
+ # Headers provides easy access and validation methods for Rack headers
9
+ class Headers
10
+ include Ext::DistributedTracing
11
+
12
+ def initialize(env)
13
+ @env = env
14
+ end
15
+
16
+ # TODO: Don't assume Rack format.
17
+ # Make distributed tracing headers apathetic.
18
+ def header(name)
19
+ rack_header = "http-#{name}".upcase!.tr('-', '_')
20
+
21
+ hdr = @env[rack_header]
22
+
23
+ # Only return the value if it is not an empty string
24
+ hdr if hdr != ''
25
+ end
26
+
27
+ def id(hdr, base = 10)
28
+ value_to_id(header(hdr), base)
29
+ end
30
+
31
+ def value_to_id(value, base = 10)
32
+ id = value_to_number(value, base)
33
+
34
+ # Return early if we could not parse a number
35
+ return if id.nil?
36
+
37
+ # Zero or greater than max allowed value of 2**64
38
+ return if id.zero? || id > Span::EXTERNAL_MAX_ID
39
+ id < 0 ? id + (2**64) : id
40
+ end
41
+
42
+ def number(hdr, base = 10)
43
+ value_to_number(header(hdr), base)
44
+ end
45
+
46
+ def value_to_number(value, base = 10)
47
+ # It's important to make a difference between no header,
48
+ # and a header defined to zero.
49
+ return if value.nil?
50
+
51
+ # Be sure we have a string
52
+ value = value.to_s
53
+
54
+ # If we are parsing base16 number then truncate to 64-bit
55
+ value = DistributedTracing::Headers::Helpers.truncate_base16_number(value) if base == 16
56
+
57
+ # Convert header to an integer
58
+ # DEV: Ruby `.to_i` will return `0` if a number could not be parsed
59
+ num = value.to_i(base)
60
+
61
+ # Ensure the parsed number is the same as the original string value
62
+ # e.g. We want to make sure to throw away `'nan'.to_i == 0`
63
+ return unless num.to_s(base) == value
64
+
65
+ num
66
+ end
67
+ end
68
+ end
69
+ end
70
+ end
@@ -0,0 +1,45 @@
1
+ require 'ddtrace/configuration'
2
+ require 'ddtrace/span'
3
+ require 'ddtrace/ext/priority'
4
+
5
+ module Datadog
6
+ module DistributedTracing
7
+ module Headers
8
+ # Helpers module provides common helper functions for distributed tracing headers
9
+ module Helpers
10
+ # Base provides common methods for distributed header helper classes
11
+ def self.clamp_sampling_priority(sampling_priority)
12
+ # B3 doesn't have our -1 (USER_REJECT) and 2 (USER_KEEP) priorities so convert to acceptable 0/1
13
+ if sampling_priority < 0
14
+ sampling_priority = Ext::Priority::AUTO_REJECT
15
+ elsif sampling_priority > 1
16
+ sampling_priority = Ext::Priority::AUTO_KEEP
17
+ end
18
+
19
+ sampling_priority
20
+ end
21
+
22
+ def self.truncate_base16_number(value)
23
+ # Lowercase if we want to parse base16 e.g. 3E8 => 3e8
24
+ # DEV: Ruby will parse `3E8` just fine, but to test
25
+ # `num.to_s(base) == value` we need to lowercase
26
+ value = value.downcase
27
+
28
+ # Truncate to trailing 16 characters if length is greater than 16
29
+ # https://github.com/apache/incubator-zipkin/blob/21fe362899fef5c593370466bc5707d3837070c2/zipkin/src/main/java/zipkin2/storage/StorageComponent.java#L49-L53
30
+ # DEV: This ensures we truncate B3 128-bit trace and span ids to 64-bit
31
+ value = value[value.length - 16, 16] if value.length > 16
32
+
33
+ # Remove any leading zeros
34
+ # DEV: When we call `num.to_s(16)` later Ruby will not add leading zeros
35
+ # for us so we want to make sure the comparision will work as expected
36
+ # DEV: regex, remove all leading zeros up until we find the last 0 in the string
37
+ # or we find the first non-zero, this allows `'0000' -> '0'` and `'00001' -> '1'`
38
+ value = value.sub(/^0*(?=(0$)|[^0])/, '')
39
+
40
+ value
41
+ end
42
+ end
43
+ end
44
+ end
45
+ end
@@ -0,0 +1,65 @@
1
+ require 'json'
2
+ require 'msgpack'
3
+
4
+ module Datadog
5
+ # Encoding module that encodes data for the AgentTransport
6
+ module Encoding
7
+ # Encoder interface that provides the logic to encode traces and service
8
+ module Encoder
9
+ def content_type
10
+ raise NotImplementedError
11
+ end
12
+
13
+ # Encodes a list of traces, expecting a list of items where each items
14
+ # is a list of spans. Before dump the string in a serialized format all
15
+ # traces are normalized. The traces nesting is not changed.
16
+ def encode_traces(traces)
17
+ to_send = []
18
+ traces.each do |trace|
19
+ to_send << trace.map(&:to_hash)
20
+ end
21
+ encode(to_send)
22
+ end
23
+
24
+ # Defines the underlying format used during traces or services encoding.
25
+ # This method must be implemented and should only be used by the internal functions.
26
+ def encode(_)
27
+ raise NotImplementedError
28
+ end
29
+ end
30
+
31
+ # Encoder for the JSON format
32
+ module JSONEncoder
33
+ extend Encoder
34
+
35
+ CONTENT_TYPE = 'application/json'.freeze
36
+
37
+ module_function
38
+
39
+ def content_type
40
+ CONTENT_TYPE
41
+ end
42
+
43
+ def encode(obj)
44
+ JSON.dump(obj)
45
+ end
46
+ end
47
+
48
+ # Encoder for the Msgpack format
49
+ module MsgpackEncoder
50
+ extend Encoder
51
+
52
+ module_function
53
+
54
+ CONTENT_TYPE = 'application/msgpack'.freeze
55
+
56
+ def content_type
57
+ CONTENT_TYPE
58
+ end
59
+
60
+ def encode(obj)
61
+ MessagePack.pack(obj)
62
+ end
63
+ end
64
+ end
65
+ end
@@ -0,0 +1,23 @@
1
+ module Datadog
2
+ # Namespace for handling application environment
3
+ module Environment
4
+ # Defines helper methods for environment
5
+ module Helpers
6
+ def env_to_bool(var, default = nil)
7
+ ENV.key?(var) ? ENV[var].to_s.downcase == 'true' : default
8
+ end
9
+
10
+ def env_to_float(var, default = nil)
11
+ ENV.key?(var) ? ENV[var].to_f : default
12
+ end
13
+
14
+ def env_to_list(var, default = [])
15
+ if ENV.key?(var)
16
+ ENV[var].split(',').map(&:strip)
17
+ else
18
+ default
19
+ end
20
+ end
21
+ end
22
+ end
23
+ end
@@ -0,0 +1,27 @@
1
+ # Datadog global namespace
2
+ module Datadog
3
+ # Error is a value-object responsible for sanitizing/encapsulating error data
4
+ class Error
5
+ attr_reader :type, :message, :backtrace
6
+
7
+ def self.build_from(value)
8
+ case value
9
+ when Error then value
10
+ when Array then new(*value)
11
+ when Exception then new(value.class, value.message, value.backtrace)
12
+ when ContainsMessage then new(value.class, value.message)
13
+ else BlankError
14
+ end
15
+ end
16
+
17
+ def initialize(type = nil, message = nil, backtrace = nil)
18
+ backtrace = Array(backtrace).join("\n")
19
+ @type = Utils.utf8_encode(type)
20
+ @message = Utils.utf8_encode(message)
21
+ @backtrace = Utils.utf8_encode(backtrace)
22
+ end
23
+
24
+ BlankError = Error.new
25
+ ContainsMessage = ->(v) { v.respond_to?(:message) }
26
+ end
27
+ end
@@ -0,0 +1,11 @@
1
+ module Datadog
2
+ module Ext
3
+ # Defines constants for trace analytics
4
+ module Analytics
5
+ DEFAULT_SAMPLE_RATE = 1.0
6
+ ENV_TRACE_ANALYTICS_ENABLED = 'DD_TRACE_ANALYTICS_ENABLED'.freeze
7
+ TAG_ENABLED = 'analytics.enabled'.freeze
8
+ TAG_SAMPLE_RATE = '_dd1.sr.eausr'.freeze
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,11 @@
1
+ module Datadog
2
+ module Ext
3
+ module AppTypes
4
+ WEB = 'web'.freeze
5
+ DB = 'db'.freeze
6
+ CACHE = 'cache'.freeze
7
+ WORKER = 'worker'.freeze
8
+ CUSTOM = 'custom'.freeze
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,25 @@
1
+ module Datadog
2
+ module Ext
3
+ module Diagnostics
4
+ # Health
5
+ module Health
6
+ # Metrics
7
+ module Metrics
8
+ ENV_ENABLED = 'DD_HEALTH_METRICS_ENABLED'.freeze
9
+
10
+ METRIC_API_ERRORS = 'datadog.tracer.api.errors'.freeze
11
+ METRIC_API_REQUESTS = 'datadog.tracer.api.requests'.freeze
12
+ METRIC_API_RESPONSES = 'datadog.tracer.api.responses'.freeze
13
+ METRIC_QUEUE_ACCEPTED = 'datadog.tracer.queue.accepted'.freeze
14
+ METRIC_QUEUE_ACCEPTED_LENGTHS = 'datadog.tracer.queue.accepted_lengths'.freeze
15
+ METRIC_QUEUE_DROPPED = 'datadog.tracer.queue.dropped'.freeze
16
+ METRIC_QUEUE_LENGTH = 'datadog.tracer.queue.length'.freeze
17
+ METRIC_QUEUE_MAX_LENGTH = 'datadog.tracer.queue.max_length'.freeze
18
+ METRIC_QUEUE_SPANS = 'datadog.tracer.queue.spans'.freeze
19
+ METRIC_TRACES_FILTERED = 'datadog.tracer.traces.filtered'.freeze
20
+ METRIC_WRITER_CPU_TIME = 'datadog.tracer.writer.cpu_time'.freeze
21
+ end
22
+ end
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,33 @@
1
+ module Datadog
2
+ module Ext
3
+ module DistributedTracing
4
+ # HTTP headers one should set for distributed tracing.
5
+ # These are cross-language (eg: Python, Go and other implementations should honor these)
6
+ HTTP_HEADER_TRACE_ID = 'x-datadog-trace-id'.freeze
7
+ HTTP_HEADER_PARENT_ID = 'x-datadog-parent-id'.freeze
8
+ HTTP_HEADER_SAMPLING_PRIORITY = 'x-datadog-sampling-priority'.freeze
9
+ SAMPLING_PRIORITY_KEY = '_sampling_priority_v1'.freeze
10
+ HTTP_HEADER_ORIGIN = 'x-datadog-origin'.freeze
11
+ ORIGIN_KEY = '_dd.origin'.freeze
12
+
13
+ # B3 headers used for distributed tracing
14
+ B3_HEADER_TRACE_ID = 'x-b3-traceid'.freeze
15
+ B3_HEADER_SPAN_ID = 'x-b3-spanid'.freeze
16
+ B3_HEADER_SAMPLED = 'x-b3-sampled'.freeze
17
+ B3_HEADER_SINGLE = 'b3'.freeze
18
+
19
+ # Distributed tracing propagation options
20
+ PROPAGATION_STYLE_DATADOG = 'Datadog'.freeze
21
+ PROPAGATION_STYLE_B3 = 'B3'.freeze
22
+ PROPAGATION_STYLE_B3_SINGLE_HEADER = 'B3 single header'.freeze
23
+ PROPAGATION_INJECT_STYLE_ENV = 'DD_PROPAGATION_INJECT_STYLE'.freeze
24
+ PROPAGATION_EXTRACT_STYLE_ENV = 'DD_PROPAGATION_EXTRACT_STYLE'.freeze
25
+
26
+ # gRPC metadata keys for distributed tracing. https://github.com/grpc/grpc-go/blob/v1.10.x/Documentation/grpc-metadata.md
27
+ GRPC_METADATA_TRACE_ID = 'x-datadog-trace-id'.freeze
28
+ GRPC_METADATA_PARENT_ID = 'x-datadog-parent-id'.freeze
29
+ GRPC_METADATA_SAMPLING_PRIORITY = 'x-datadog-sampling-priority'.freeze
30
+ GRPC_METADATA_ORIGIN = 'x-datadog-origin'.freeze
31
+ end
32
+ end
33
+ end