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,9 @@
1
+ production:
2
+ adapter: 'postgresql'
3
+ timeout: 5000
4
+ database: <%= ENV.fetch('TEST_POSTGRES_DB', 'postgres') %>
5
+ host: <%= ENV.fetch('TEST_POSTGRES_HOST', '127.0.0.1') %>
6
+ port: <%= ENV.fetch('TEST_POSTGRES_PORT', 5432) %>
7
+ username: <%= ENV.fetch('TEST_POSTGRES_USER', 'postgres') %>
8
+ password: <%= ENV.fetch('TEST_POSTGRES_PASSWORD', 'postgres') %>
9
+ pool: 30
@@ -0,0 +1,154 @@
1
+ ENV['RAILS_ENV'] = 'production'
2
+ require 'English'
3
+
4
+ # Benchmark Configuration container
5
+ module TestConfiguration
6
+ module_function
7
+
8
+ def sidekiq
9
+ Sidekiq.options.tap do |options|
10
+ options[:tag] = 'test'
11
+ options[:queues] << 'default'
12
+ options[:concurrency] = 20
13
+ options[:timeout] = 2
14
+ end
15
+ end
16
+
17
+ def redis
18
+ { pool_size: 30, timeout: 3 }
19
+ end
20
+
21
+ def iteration_count
22
+ 1000
23
+ end
24
+ end
25
+
26
+ require 'bundler/setup'
27
+ require 'rails/all'
28
+ Bundler.require(*Rails.groups)
29
+
30
+ # Example Rails App
31
+ module SampleApp
32
+ class Application < Rails::Application; end
33
+ end
34
+
35
+ # Overrides rails configueration locations
36
+ module OverrideConfiguration
37
+ def paths
38
+ super.tap { |path| path.add 'config/database', with: 'benchmarks/postgres_database.yml' }
39
+ end
40
+ end
41
+
42
+ Rails::Application::Configuration.prepend(OverrideConfiguration)
43
+
44
+ Rails.application.configure do
45
+ config.cache_classes = true
46
+ config.eager_load = true
47
+ config.active_job.queue_adapter = :sidekiq
48
+ end
49
+
50
+ ActiveRecord::Base.configurations = Rails.application.config.database_configuration
51
+ Rails.application.initialize!
52
+
53
+ ActiveRecord::Schema.define do
54
+ drop_table(:samples) if connection.table_exists?(:samples)
55
+
56
+ create_table :samples do |t|
57
+ t.string :name
58
+ t.timestamps
59
+ end
60
+ end
61
+
62
+ class Sample < ActiveRecord::Base; end
63
+
64
+ require 'sidekiq/launcher'
65
+ require 'sidekiq/cli'
66
+ require 'concurrent/atomic/atomic_fixnum'
67
+
68
+ Sidekiq.configure_server do |config|
69
+ redis_conn = proc do
70
+ Redis.new(
71
+ host: ENV.fetch('TEST_REDIS_HOST', '127.0.0.1'),
72
+ port: ENV.fetch('TEST_REDIS_PORT', 6379)
73
+ )
74
+ end
75
+ config.redis = ConnectionPool.new(size: TestConfiguration.redis[:pool_size],
76
+ timeout: TestConfiguration.redis[:timeout],
77
+ &redis_conn)
78
+ end
79
+
80
+ # Simple Sidekiq worker performing the real benchmark
81
+ class Worker
82
+ class << self
83
+ attr_reader :iterations, :conditional_variable
84
+ end
85
+
86
+ @iterations = Concurrent::AtomicFixnum.new(0)
87
+ @conditional_variable = ConditionVariable.new
88
+
89
+ include Sidekiq::Worker
90
+ def perform(iter, max_iterations)
91
+ self.class.iterations.increment
92
+ self.class.conditional_variable.broadcast if self.class.iterations.value > max_iterations
93
+
94
+ Sample.create!(name: iter.to_s).save
95
+
96
+ 100.times do
97
+ Sample.last.name
98
+ end
99
+
100
+ Sample.last(100).to_a
101
+ end
102
+ end
103
+
104
+ if Datadog.respond_to?(:configure)
105
+ Datadog.configure do |d|
106
+ d.use :rails, enabled: true, tags: { 'tag' => 'value' }
107
+ d.use :http
108
+ d.use :sidekiq, service_name: 'service'
109
+ d.use :redis
110
+ d.use :dalli
111
+ d.use :resque, workers: [Worker]
112
+
113
+ processor = Datadog::Pipeline::SpanProcessor.new do |span|
114
+ true if span.service == 'B'
115
+ end
116
+
117
+ Datadog::Pipeline.before_flush(processor)
118
+ end
119
+ end
120
+
121
+ def current_memory
122
+ `ps -o rss #{$PROCESS_ID}`.split("\n")[1].to_f / 1024
123
+ end
124
+
125
+ def time
126
+ Process.clock_gettime(Process::CLOCK_MONOTONIC)
127
+ end
128
+
129
+ def launch(iterations, options)
130
+ iterations.times do |i|
131
+ Worker.perform_async(i, iterations)
132
+ end
133
+
134
+ launcher = Sidekiq::Launcher.new(options)
135
+ launcher.run
136
+ end
137
+
138
+ def wait_and_measure(iterations)
139
+ start = time
140
+
141
+ STDERR.puts "#{time - start}, #{current_memory}"
142
+
143
+ mutex = Mutex.new
144
+
145
+ while Worker.iterations.value < iterations
146
+ mutex.synchronize do
147
+ Worker.conditional_variable.wait(mutex, 1)
148
+ STDERR.puts "#{time - start}, #{current_memory}"
149
+ end
150
+ end
151
+ end
152
+
153
+ launch(TestConfiguration.iteration_count, TestConfiguration.sidekiq)
154
+ wait_and_measure(TestConfiguration.iteration_count)
@@ -0,0 +1,63 @@
1
+ # coding: utf-8
2
+
3
+ lib = File.expand_path('../lib', __FILE__)
4
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
5
+ require 'ddtrace/version'
6
+
7
+ Gem::Specification.new do |spec|
8
+ spec.name = 'ls-trace'
9
+ spec.version = Datadog::VERSION::STRING
10
+ spec.required_ruby_version = ">= #{Datadog::VERSION::MINIMUM_RUBY_VERSION}"
11
+ spec.authors = ['lightstep']
12
+ spec.email = ['support@lightstep.com']
13
+
14
+ spec.summary = 'LightStep fork of dd-trace for tracing code for your Ruby applications'
15
+ spec.description = <<-EOS.gsub(/^[\s]+/, '')
16
+ ls-trace is LightStep's fork of Datadog’s tracing client for Ruby. It
17
+ is used to trace requests as they flow across web servers, databases and
18
+ microservices so that developers have great visiblity into bottlenecks and
19
+ troublesome requests.
20
+ EOS
21
+
22
+ spec.homepage = 'https://github.com/lightstep/dd-trace-rb'
23
+ spec.license = 'BSD-3-Clause'
24
+
25
+ if spec.respond_to?(:metadata)
26
+ spec.metadata['allowed_push_host'] = 'https://rubygems.org'
27
+ else
28
+ raise 'RubyGems 2.0 or newer is required to protect against public gem pushes.'
29
+ end
30
+
31
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
32
+ spec.bindir = 'exe'
33
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
34
+ spec.require_paths = ['lib']
35
+
36
+ spec.add_dependency 'msgpack'
37
+
38
+ # Optional extensions
39
+ # TODO: Move this to Appraisals?
40
+ spec.add_development_dependency 'dogstatsd-ruby', '>= 3.3.0'
41
+ spec.add_development_dependency 'opentracing', '>= 0.4.1'
42
+
43
+ # Development dependencies
44
+ spec.add_development_dependency 'rake', '>= 10.5'
45
+ spec.add_development_dependency 'rubocop', '= 0.49.1' if RUBY_VERSION >= '2.1.0'
46
+ spec.add_development_dependency 'rspec', '~> 3.0'
47
+ spec.add_development_dependency 'rspec-collection_matchers', '~> 1.1'
48
+ spec.add_development_dependency 'minitest', '= 5.10.1'
49
+ spec.add_development_dependency 'appraisal', '~> 2.2'
50
+ spec.add_development_dependency 'yard', '~> 0.9'
51
+ spec.add_development_dependency 'webmock', '~> 2.0'
52
+ spec.add_development_dependency 'builder'
53
+ spec.add_development_dependency 'ruby-prof'
54
+ spec.add_development_dependency 'sqlite3', '~> 1.3.6'
55
+ spec.add_development_dependency 'climate_control', '~> 0.2.0'
56
+
57
+ # locking transitive dependency of webmock
58
+ spec.add_development_dependency 'addressable', '~> 2.4.0'
59
+ spec.add_development_dependency 'redcarpet', '~> 3.4' if RUBY_PLATFORM != 'java'
60
+ spec.add_development_dependency 'pry', '~> 0.10.4'
61
+ spec.add_development_dependency 'pry-stack_explorer', '~> 0.4.9.2'
62
+ spec.add_development_dependency 'warning' if RUBY_VERSION >= '2.5.0'
63
+ end
@@ -0,0 +1,276 @@
1
+ version: '3.2'
2
+ services:
3
+ tracer-2.0:
4
+ image: palazzem/docker-library:ddtrace_rb_2_0_0
5
+ command: /bin/bash
6
+ depends_on:
7
+ - ddagent
8
+ - elasticsearch
9
+ - memcached
10
+ - mongodb
11
+ - mysql
12
+ - postgres
13
+ - redis
14
+ env_file: ./.env
15
+ environment:
16
+ - BUNDLE_GEMFILE=/app/Gemfile
17
+ - DD_AGENT_HOST=ddagent
18
+ - TEST_DATADOG_INTEGRATION=1
19
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
20
+ - TEST_MEMCACHED_HOST=memcached
21
+ - TEST_MONGODB_HOST=mongodb
22
+ - TEST_MYSQL_HOST=mysql
23
+ - TEST_POSTGRES_HOST=postgres
24
+ - TEST_REDIS_HOST=redis
25
+ stdin_open: true
26
+ tty: true
27
+ volumes:
28
+ - .:/app
29
+ - bundle-2.0:/usr/local/bundle
30
+ - gemfiles-2.0:/app/gemfiles
31
+ tracer-2.1:
32
+ image: palazzem/docker-library:ddtrace_rb_2_1_10
33
+ command: /bin/bash
34
+ depends_on:
35
+ - ddagent
36
+ - elasticsearch
37
+ - memcached
38
+ - mongodb
39
+ - mysql
40
+ - postgres
41
+ - redis
42
+ env_file: ./.env
43
+ environment:
44
+ - BUNDLE_GEMFILE=/app/Gemfile
45
+ - DD_AGENT_HOST=ddagent
46
+ - TEST_DATADOG_INTEGRATION=1
47
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
48
+ - TEST_MEMCACHED_HOST=memcached
49
+ - TEST_MONGODB_HOST=mongodb
50
+ - TEST_MYSQL_HOST=mysql
51
+ - TEST_POSTGRES_HOST=postgres
52
+ - TEST_REDIS_HOST=redis
53
+ stdin_open: true
54
+ tty: true
55
+ volumes:
56
+ - .:/app
57
+ - bundle-2.1:/usr/local/bundle
58
+ - gemfiles-2.1:/app/gemfiles
59
+ tracer-2.2:
60
+ image: palazzem/docker-library:ddtrace_rb_2_2_10
61
+ command: /bin/bash
62
+ depends_on:
63
+ - ddagent
64
+ - elasticsearch
65
+ - memcached
66
+ - mongodb
67
+ - mysql
68
+ - postgres
69
+ - redis
70
+ env_file: ./.env
71
+ environment:
72
+ - BUNDLE_GEMFILE=/app/Gemfile
73
+ - DD_AGENT_HOST=ddagent
74
+ - TEST_DATADOG_INTEGRATION=1
75
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
76
+ - TEST_MEMCACHED_HOST=memcached
77
+ - TEST_MONGODB_HOST=mongodb
78
+ - TEST_MYSQL_HOST=mysql
79
+ - TEST_POSTGRES_HOST=postgres
80
+ - TEST_REDIS_HOST=redis
81
+ stdin_open: true
82
+ tty: true
83
+ volumes:
84
+ - .:/app
85
+ - bundle-2.2:/usr/local/bundle
86
+ - gemfiles-2.2:/app/gemfiles
87
+ tracer-2.3:
88
+ image: palazzem/docker-library:ddtrace_rb_2_3_8
89
+ command: /bin/bash
90
+ depends_on:
91
+ - ddagent
92
+ - elasticsearch
93
+ - memcached
94
+ - mongodb
95
+ - mysql
96
+ - postgres
97
+ - redis
98
+ env_file: ./.env
99
+ environment:
100
+ - BUNDLE_GEMFILE=/app/Gemfile
101
+ - DD_AGENT_HOST=ddagent
102
+ - TEST_DATADOG_INTEGRATION=1
103
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
104
+ - TEST_MEMCACHED_HOST=memcached
105
+ - TEST_MONGODB_HOST=mongodb
106
+ - TEST_MYSQL_HOST=mysql
107
+ - TEST_POSTGRES_HOST=postgres
108
+ - TEST_REDIS_HOST=redis
109
+ stdin_open: true
110
+ tty: true
111
+ volumes:
112
+ - .:/app
113
+ - bundle-2.3:/usr/local/bundle
114
+ - gemfiles-2.3:/app/gemfiles
115
+ tracer-2.4:
116
+ image: palazzem/docker-library:ddtrace_rb_2_4_6
117
+ command: /bin/bash
118
+ depends_on:
119
+ - ddagent
120
+ - elasticsearch
121
+ - memcached
122
+ - mongodb
123
+ - mysql
124
+ - postgres
125
+ - redis
126
+ env_file: ./.env
127
+ environment:
128
+ - BUNDLE_GEMFILE=/app/Gemfile
129
+ - DD_AGENT_HOST=ddagent
130
+ - TEST_DATADOG_INTEGRATION=1
131
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
132
+ - TEST_MEMCACHED_HOST=memcached
133
+ - TEST_MONGODB_HOST=mongodb
134
+ - TEST_MYSQL_HOST=mysql
135
+ - TEST_POSTGRES_HOST=postgres
136
+ - TEST_REDIS_HOST=redis
137
+ stdin_open: true
138
+ tty: true
139
+ volumes:
140
+ - .:/app
141
+ - bundle-2.4:/usr/local/bundle
142
+ - gemfiles-2.4:/app/gemfiles
143
+ tracer-2.5:
144
+ image: marcotc/docker-library:ddtrace_rb_2_5_6
145
+ command: /bin/bash
146
+ depends_on:
147
+ - ddagent
148
+ - elasticsearch
149
+ - memcached
150
+ - mongodb
151
+ - mysql
152
+ - postgres
153
+ - redis
154
+ env_file: ./.env
155
+ environment:
156
+ - BUNDLE_GEMFILE=/app/Gemfile
157
+ - DD_AGENT_HOST=ddagent
158
+ - TEST_DATADOG_INTEGRATION=1
159
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
160
+ - TEST_MEMCACHED_HOST=memcached
161
+ - TEST_MONGODB_HOST=mongodb
162
+ - TEST_MYSQL_HOST=mysql
163
+ - TEST_POSTGRES_HOST=postgres
164
+ - TEST_REDIS_HOST=redis
165
+ stdin_open: true
166
+ tty: true
167
+ volumes:
168
+ - .:/app
169
+ - bundle-2.5:/usr/local/bundle
170
+ - gemfiles-2.5:/app/gemfiles
171
+ tracer-2.6:
172
+ image: marcotc/docker-library:ddtrace_rb_2_6_4
173
+ command: /bin/bash
174
+ depends_on:
175
+ - ddagent
176
+ - elasticsearch
177
+ - memcached
178
+ - mongodb
179
+ - mysql
180
+ - postgres
181
+ - redis
182
+ env_file: ./.env
183
+ environment:
184
+ - BUNDLE_GEMFILE=/app/Gemfile
185
+ - DD_AGENT_HOST=ddagent
186
+ - TEST_DATADOG_INTEGRATION=1
187
+ - TEST_ELASTICSEARCH_HOST=elasticsearch
188
+ - TEST_MEMCACHED_HOST=memcached
189
+ - TEST_MONGODB_HOST=mongodb
190
+ - TEST_MYSQL_HOST=mysql
191
+ - TEST_POSTGRES_HOST=postgres
192
+ - TEST_REDIS_HOST=redis
193
+ stdin_open: true
194
+ tty: true
195
+ volumes:
196
+ - .:/app
197
+ - bundle-2.6:/usr/local/bundle
198
+ - gemfiles-2.6:/app/gemfiles
199
+ ddagent:
200
+ image: datadog/docker-dd-agent
201
+ environment:
202
+ - DD_APM_ENABLED=true
203
+ - DD_BIND_HOST=0.0.0.0
204
+ - DD_API_KEY=invalid_key_but_this_is_fine
205
+ expose:
206
+ - "8125/udp"
207
+ - "8126"
208
+ ports:
209
+ - "${DD_METRIC_AGENT_PORT}:8125/udp"
210
+ - "${DD_TRACE_AGENT_PORT}:8126"
211
+ elasticsearch:
212
+ # Note: ES 5.0 dies with error:
213
+ # max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
214
+ # see https://github.com/docker-library/elasticsearch/issues/98 for details
215
+ # For now, just rely on a 2.X server.
216
+ image: elasticsearch:2.4
217
+ expose:
218
+ - "9200"
219
+ - "9300"
220
+ ports:
221
+ - "${TEST_ELASTICSEARCH_REST_PORT}:9200"
222
+ - "${TEST_ELASTICSEARCH_NATIVE_PORT}:9300"
223
+ memcached:
224
+ image: memcached:1.5-alpine
225
+ expose:
226
+ - "11211"
227
+ ports:
228
+ - "${TEST_MEMCACHED_PORT}:11211"
229
+ mongodb:
230
+ image: mongo:3.5
231
+ expose:
232
+ - "27017"
233
+ ports:
234
+ - "${TEST_MONGODB_PORT}:27017"
235
+ mysql:
236
+ image: mysql:5.6
237
+ environment:
238
+ - MYSQL_DATABASE=$TEST_MYSQL_DB
239
+ - MYSQL_ROOT_PASSWORD=$TEST_MYSQL_ROOT_PASSWORD
240
+ - MYSQL_PASSWORD=$TEST_MYSQL_PASSWORD
241
+ - MYSQL_USER=$TEST_MYSQL_USER
242
+ expose:
243
+ - "3306"
244
+ ports:
245
+ - "${TEST_MYSQL_PORT}:3306"
246
+ postgres:
247
+ image: postgres:9.6
248
+ environment:
249
+ - POSTGRES_PASSWORD=$TEST_POSTGRES_PASSWORD
250
+ - POSTGRES_USER=$TEST_POSTGRES_USER
251
+ - POSTGRES_DB=$TEST_POSTGRES_DB
252
+ expose:
253
+ - "5432"
254
+ ports:
255
+ - "${TEST_POSTGRES_PORT}:5432"
256
+ redis:
257
+ image: redis:3.0
258
+ expose:
259
+ - "6379"
260
+ ports:
261
+ - "${TEST_REDIS_PORT}:6379"
262
+ volumes:
263
+ bundle-2.0:
264
+ bundle-2.1:
265
+ bundle-2.2:
266
+ bundle-2.3:
267
+ bundle-2.4:
268
+ bundle-2.5:
269
+ bundle-2.6:
270
+ gemfiles-2.0:
271
+ gemfiles-2.1:
272
+ gemfiles-2.2:
273
+ gemfiles-2.3:
274
+ gemfiles-2.4:
275
+ gemfiles-2.5:
276
+ gemfiles-2.6: