scout_apm 2.6.10 → 3.0.0.pre0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (233) hide show
  1. checksums.yaml +5 -5
  2. data/.gitignore +1 -2
  3. data/.rubocop.yml +3 -11
  4. data/CHANGELOG.markdown +4 -362
  5. data/Gemfile +1 -14
  6. data/README.markdown +7 -52
  7. data/Rakefile +1 -0
  8. data/ext/allocations/allocations.c +1 -7
  9. data/ext/allocations/extconf.rb +0 -1
  10. data/ext/rusage/rusage.c +0 -26
  11. data/ext/stacks/extconf.rb +37 -0
  12. data/ext/stacks/scout_atomics.h +86 -0
  13. data/ext/stacks/stacks.c +811 -0
  14. data/lib/scout_apm/agent/logging.rb +69 -0
  15. data/lib/scout_apm/agent/reporting.rb +126 -0
  16. data/lib/scout_apm/agent.rb +259 -138
  17. data/lib/scout_apm/app_server_load.rb +15 -41
  18. data/lib/scout_apm/attribute_arranger.rb +3 -14
  19. data/lib/scout_apm/background_job_integrations/delayed_job.rb +1 -70
  20. data/lib/scout_apm/background_job_integrations/sidekiq.rb +24 -31
  21. data/lib/scout_apm/background_worker.rb +12 -23
  22. data/lib/scout_apm/capacity.rb +57 -0
  23. data/lib/scout_apm/config.rb +37 -206
  24. data/lib/scout_apm/context.rb +4 -20
  25. data/lib/scout_apm/deploy_integrations/capistrano_2.cap +12 -0
  26. data/lib/scout_apm/deploy_integrations/capistrano_2.rb +83 -0
  27. data/lib/scout_apm/deploy_integrations/capistrano_3.cap +12 -0
  28. data/lib/scout_apm/deploy_integrations/capistrano_3.rb +88 -0
  29. data/lib/scout_apm/environment.rb +28 -42
  30. data/lib/scout_apm/fake_store.rb +0 -12
  31. data/lib/scout_apm/framework_integrations/rails_2.rb +1 -2
  32. data/lib/scout_apm/framework_integrations/rails_3_or_4.rb +6 -17
  33. data/lib/scout_apm/framework_integrations/sinatra.rb +1 -1
  34. data/lib/scout_apm/histogram.rb +3 -12
  35. data/lib/scout_apm/instant/assets/xmlhttp_instrumentation.html +2 -2
  36. data/lib/scout_apm/instant/middleware.rb +54 -202
  37. data/lib/scout_apm/instant_reporting.rb +7 -7
  38. data/lib/scout_apm/instruments/.DS_Store +0 -0
  39. data/lib/scout_apm/instruments/action_controller_rails_2.rb +9 -15
  40. data/lib/scout_apm/instruments/action_controller_rails_3_rails4.rb +76 -124
  41. data/lib/scout_apm/instruments/active_record.rb +29 -324
  42. data/lib/scout_apm/instruments/delayed_job.rb +57 -0
  43. data/lib/scout_apm/instruments/elasticsearch.rb +6 -10
  44. data/lib/scout_apm/instruments/grape.rb +9 -12
  45. data/lib/scout_apm/instruments/http_client.rb +7 -14
  46. data/lib/scout_apm/instruments/influxdb.rb +6 -10
  47. data/lib/scout_apm/instruments/middleware_detailed.rb +11 -15
  48. data/lib/scout_apm/instruments/middleware_summary.rb +5 -11
  49. data/lib/scout_apm/instruments/mongoid.rb +8 -39
  50. data/lib/scout_apm/instruments/moped.rb +6 -11
  51. data/lib/scout_apm/instruments/net_http.rb +9 -27
  52. data/lib/scout_apm/instruments/percentile_sampler.rb +23 -42
  53. data/lib/scout_apm/instruments/process/process_cpu.rb +6 -11
  54. data/lib/scout_apm/instruments/process/process_memory.rb +12 -17
  55. data/lib/scout_apm/instruments/rails_router.rb +6 -12
  56. data/lib/scout_apm/instruments/redis.rb +6 -10
  57. data/lib/scout_apm/instruments/sinatra.rb +4 -5
  58. data/lib/scout_apm/job_record.rb +2 -4
  59. data/lib/scout_apm/layaway.rb +34 -88
  60. data/lib/scout_apm/layaway_file.rb +3 -13
  61. data/lib/scout_apm/layer.rb +60 -25
  62. data/lib/scout_apm/layer_converters/allocation_metric_converter.rb +6 -7
  63. data/lib/scout_apm/layer_converters/converter_base.rb +14 -203
  64. data/lib/scout_apm/layer_converters/depth_first_walker.rb +10 -22
  65. data/lib/scout_apm/layer_converters/error_converter.rb +8 -8
  66. data/lib/scout_apm/layer_converters/job_converter.rb +50 -37
  67. data/lib/scout_apm/layer_converters/metric_converter.rb +19 -18
  68. data/lib/scout_apm/layer_converters/request_queue_time_converter.rb +13 -13
  69. data/lib/scout_apm/layer_converters/slow_job_converter.rb +116 -52
  70. data/lib/scout_apm/layer_converters/slow_request_converter.rb +120 -51
  71. data/lib/scout_apm/metric_meta.rb +5 -0
  72. data/lib/scout_apm/metric_set.rb +1 -9
  73. data/lib/scout_apm/metric_stats.rb +8 -7
  74. data/lib/scout_apm/middleware.rb +9 -7
  75. data/lib/scout_apm/reporter.rb +24 -71
  76. data/lib/scout_apm/request_histograms.rb +0 -12
  77. data/lib/scout_apm/request_manager.rb +7 -5
  78. data/lib/scout_apm/scored_item_set.rb +0 -7
  79. data/lib/scout_apm/serializers/app_server_load_serializer.rb +0 -4
  80. data/lib/scout_apm/serializers/deploy_serializer.rb +16 -0
  81. data/lib/scout_apm/serializers/directive_serializer.rb +0 -4
  82. data/lib/scout_apm/serializers/payload_serializer.rb +4 -11
  83. data/lib/scout_apm/serializers/payload_serializer_to_json.rb +16 -35
  84. data/lib/scout_apm/serializers/slow_jobs_serializer_to_json.rb +1 -2
  85. data/lib/scout_apm/server_integrations/passenger.rb +1 -1
  86. data/lib/scout_apm/server_integrations/puma.rb +2 -5
  87. data/lib/scout_apm/slow_job_policy.rb +13 -25
  88. data/lib/scout_apm/slow_job_record.rb +4 -13
  89. data/lib/scout_apm/slow_request_policy.rb +13 -25
  90. data/lib/scout_apm/slow_transaction.rb +5 -25
  91. data/lib/scout_apm/store.rb +32 -99
  92. data/lib/scout_apm/trace_compactor.rb +312 -0
  93. data/lib/scout_apm/tracer.rb +31 -35
  94. data/lib/scout_apm/tracked_request.rb +95 -262
  95. data/lib/scout_apm/utils/active_record_metric_name.rb +13 -88
  96. data/lib/scout_apm/utils/backtrace_parser.rb +4 -7
  97. data/lib/scout_apm/utils/fake_stacks.rb +87 -0
  98. data/lib/scout_apm/utils/installed_gems.rb +3 -7
  99. data/lib/scout_apm/utils/klass_helper.rb +2 -8
  100. data/lib/scout_apm/utils/null_logger.rb +13 -0
  101. data/lib/scout_apm/utils/sql_sanitizer.rb +5 -16
  102. data/lib/scout_apm/utils/sql_sanitizer_regex.rb +0 -7
  103. data/lib/scout_apm/utils/sql_sanitizer_regex_1_8_7.rb +0 -6
  104. data/lib/scout_apm/utils/unique_id.rb +0 -27
  105. data/lib/scout_apm/version.rb +2 -1
  106. data/lib/scout_apm.rb +25 -84
  107. data/scout_apm.gemspec +3 -17
  108. data/test/test_helper.rb +3 -57
  109. data/test/unit/agent_test.rb +54 -1
  110. data/test/unit/background_job_integrations/sidekiq_test.rb +3 -0
  111. data/test/unit/config_test.rb +12 -25
  112. data/test/unit/context_test.rb +4 -4
  113. data/test/unit/histogram_test.rb +4 -25
  114. data/test/unit/ignored_uris_test.rb +1 -1
  115. data/test/unit/instruments/active_record_instruments_test.rb +5 -0
  116. data/test/unit/layaway_test.rb +2 -62
  117. data/test/unit/serializers/payload_serializer_test.rb +15 -43
  118. data/test/unit/slow_request_policy_test.rb +6 -15
  119. data/test/unit/sql_sanitizer_test.rb +6 -53
  120. data/test/unit/store_test.rb +4 -73
  121. data/test/unit/utils/active_record_metric_name_test.rb +5 -59
  122. data/test/unit/utils/backtrace_parser_test.rb +1 -6
  123. data/tester.rb +53 -0
  124. metadata +28 -229
  125. data/.travis.yml +0 -26
  126. data/Guardfile +0 -43
  127. data/gems/README.md +0 -28
  128. data/gems/octoshark.gemfile +0 -4
  129. data/gems/rails3.gemfile +0 -5
  130. data/gems/rails4.gemfile +0 -4
  131. data/gems/rails5.gemfile +0 -4
  132. data/gems/rails6.gemfile +0 -4
  133. data/lib/scout_apm/agent/exit_handler.rb +0 -65
  134. data/lib/scout_apm/agent/preconditions.rb +0 -81
  135. data/lib/scout_apm/agent_context.rb +0 -261
  136. data/lib/scout_apm/auto_instrument/instruction_sequence.rb +0 -31
  137. data/lib/scout_apm/auto_instrument/layer.rb +0 -23
  138. data/lib/scout_apm/auto_instrument/parser.rb +0 -27
  139. data/lib/scout_apm/auto_instrument/rails.rb +0 -175
  140. data/lib/scout_apm/auto_instrument.rb +0 -5
  141. data/lib/scout_apm/background_job_integrations/legacy_sneakers.rb +0 -55
  142. data/lib/scout_apm/background_job_integrations/que.rb +0 -134
  143. data/lib/scout_apm/background_job_integrations/resque.rb +0 -88
  144. data/lib/scout_apm/background_job_integrations/shoryuken.rb +0 -124
  145. data/lib/scout_apm/background_job_integrations/sneakers.rb +0 -87
  146. data/lib/scout_apm/background_recorder.rb +0 -48
  147. data/lib/scout_apm/db_query_metric_set.rb +0 -97
  148. data/lib/scout_apm/db_query_metric_stats.rb +0 -102
  149. data/lib/scout_apm/debug.rb +0 -37
  150. data/lib/scout_apm/detailed_trace.rb +0 -217
  151. data/lib/scout_apm/error.rb +0 -27
  152. data/lib/scout_apm/error_service/error_buffer.rb +0 -39
  153. data/lib/scout_apm/error_service/error_record.rb +0 -211
  154. data/lib/scout_apm/error_service/ignored_exceptions.rb +0 -66
  155. data/lib/scout_apm/error_service/middleware.rb +0 -32
  156. data/lib/scout_apm/error_service/notifier.rb +0 -33
  157. data/lib/scout_apm/error_service/payload.rb +0 -47
  158. data/lib/scout_apm/error_service/periodic_work.rb +0 -17
  159. data/lib/scout_apm/error_service/railtie.rb +0 -11
  160. data/lib/scout_apm/error_service/sidekiq.rb +0 -80
  161. data/lib/scout_apm/error_service.rb +0 -32
  162. data/lib/scout_apm/extensions/config.rb +0 -87
  163. data/lib/scout_apm/extensions/transaction_callback_payload.rb +0 -74
  164. data/lib/scout_apm/git_revision.rb +0 -59
  165. data/lib/scout_apm/instrument_manager.rb +0 -88
  166. data/lib/scout_apm/instruments/action_view.rb +0 -141
  167. data/lib/scout_apm/instruments/http.rb +0 -48
  168. data/lib/scout_apm/instruments/memcached.rb +0 -43
  169. data/lib/scout_apm/instruments/resque.rb +0 -39
  170. data/lib/scout_apm/instruments/samplers.rb +0 -11
  171. data/lib/scout_apm/layer_children_set.rb +0 -86
  172. data/lib/scout_apm/layer_converters/database_converter.rb +0 -70
  173. data/lib/scout_apm/layer_converters/find_layer_by_type.rb +0 -38
  174. data/lib/scout_apm/layer_converters/histograms.rb +0 -15
  175. data/lib/scout_apm/layer_converters/trace_converter.rb +0 -184
  176. data/lib/scout_apm/limited_layer.rb +0 -126
  177. data/lib/scout_apm/logger.rb +0 -158
  178. data/lib/scout_apm/periodic_work.rb +0 -47
  179. data/lib/scout_apm/rack.rb +0 -26
  180. data/lib/scout_apm/remote/message.rb +0 -27
  181. data/lib/scout_apm/remote/recorder.rb +0 -57
  182. data/lib/scout_apm/remote/router.rb +0 -49
  183. data/lib/scout_apm/remote/server.rb +0 -60
  184. data/lib/scout_apm/reporting.rb +0 -143
  185. data/lib/scout_apm/serializers/db_query_serializer_to_json.rb +0 -15
  186. data/lib/scout_apm/serializers/histograms_serializer_to_json.rb +0 -21
  187. data/lib/scout_apm/synchronous_recorder.rb +0 -30
  188. data/lib/scout_apm/tasks/doctor.rb +0 -75
  189. data/lib/scout_apm/tasks/support.rb +0 -22
  190. data/lib/scout_apm/transaction.rb +0 -13
  191. data/lib/scout_apm/transaction_time_consumed.rb +0 -51
  192. data/lib/scout_apm/utils/gzip_helper.rb +0 -24
  193. data/lib/scout_apm/utils/marshal_logging.rb +0 -90
  194. data/lib/scout_apm/utils/numbers.rb +0 -14
  195. data/lib/scout_apm/utils/scm.rb +0 -14
  196. data/lib/tasks/doctor.rake +0 -11
  197. data/test/tmp/README.md +0 -17
  198. data/test/unit/agent_context_test.rb +0 -15
  199. data/test/unit/auto_instrument/assignments-instrumented.rb +0 -31
  200. data/test/unit/auto_instrument/assignments.rb +0 -31
  201. data/test/unit/auto_instrument/controller-ast.txt +0 -57
  202. data/test/unit/auto_instrument/controller-instrumented.rb +0 -49
  203. data/test/unit/auto_instrument/controller.rb +0 -49
  204. data/test/unit/auto_instrument/rescue_from-instrumented.rb +0 -13
  205. data/test/unit/auto_instrument/rescue_from.rb +0 -13
  206. data/test/unit/auto_instrument_test.rb +0 -54
  207. data/test/unit/db_query_metric_set_test.rb +0 -67
  208. data/test/unit/db_query_metric_stats_test.rb +0 -113
  209. data/test/unit/error_service/error_buffer_test.rb +0 -25
  210. data/test/unit/error_service/ignored_exceptions_test.rb +0 -49
  211. data/test/unit/extensions/periodic_callbacks_test.rb +0 -58
  212. data/test/unit/extensions/transaction_callbacks_test.rb +0 -58
  213. data/test/unit/fake_store_test.rb +0 -10
  214. data/test/unit/git_revision_test.rb +0 -15
  215. data/test/unit/instruments/active_record_test.rb +0 -40
  216. data/test/unit/instruments/net_http_test.rb +0 -27
  217. data/test/unit/instruments/percentile_sampler_test.rb +0 -133
  218. data/test/unit/layer_children_set_test.rb +0 -97
  219. data/test/unit/layer_converters/depth_first_walker_test.rb +0 -70
  220. data/test/unit/layer_converters/metric_converter_test.rb +0 -22
  221. data/test/unit/layer_converters/stubs.rb +0 -33
  222. data/test/unit/limited_layer_test.rb +0 -53
  223. data/test/unit/logger_test.rb +0 -69
  224. data/test/unit/remote/test_message.rb +0 -13
  225. data/test/unit/remote/test_router.rb +0 -33
  226. data/test/unit/remote/test_server.rb +0 -15
  227. data/test/unit/request_histograms_test.rb +0 -17
  228. data/test/unit/tracer_test.rb +0 -76
  229. data/test/unit/tracked_request_test.rb +0 -71
  230. data/test/unit/transaction_test.rb +0 -14
  231. data/test/unit/transaction_time_consumed_test.rb +0 -46
  232. data/test/unit/utils/numbers_test.rb +0 -15
  233. data/test/unit/utils/scm.rb +0 -17
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA256:
3
- metadata.gz: 503d33cb7c689cb239c328bee4ba2a1df380df703f3e3a6f5f843676b9bff0e4
4
- data.tar.gz: 444e240dc8c4922ee932684c1c10b3fb5d658e96228c901b33a9a5ca3cb1e469
2
+ SHA1:
3
+ metadata.gz: afa1d7b25baf3d94a547899966b95419ac560d07
4
+ data.tar.gz: d6201d2acc85f2e94c92315b8193d110a4febd0a
5
5
  SHA512:
6
- metadata.gz: 715c6a3f044d2091207667fc6a9857573da528cf03ee5d64ccb758c10ec387b49829a891ae43bb51b444077c898f57fc73257f2d963407820ed7114fdedb52c4
7
- data.tar.gz: 373b60dc42e0417e6003698c143138ff50024802285ff3754cc706efc1bc305a941fddbe27e6a471d8f09b3ffc84b5a3cfb43e57a1715968d7cac47ee069f5b3
6
+ metadata.gz: 9a125da761d39c62094fc48ca66163bac787c0de62e9b6a3f38e984ae2ab8f41dcc7d271519764694c6b9a194e084c626bbf7b042a364ee56afe524c912fd83a
7
+ data.tar.gz: cce9304bd70490eb711c92a6df03d656710c01eb0343f809e58d0bb49c02ec152a99f668b21f7e51424aec34e432286c0ec83f7cdc74cdc994300ae6aa0b4ed6
data/.gitignore CHANGED
@@ -17,5 +17,4 @@ test/tmp/*coverage/*
17
17
  coverage/*
18
18
  lib/*.bundle
19
19
  lib/*.so
20
- log/scout_apm.log
21
- gems/*.lock
20
+ **/.RUBYARCHDIR.time
data/.rubocop.yml CHANGED
@@ -1,16 +1,8 @@
1
- # Disable all cops by default
2
- AllCops:
3
- DisabledByDefault: true
4
- Exclude:
5
- - 'test/unit/auto_instrument/*'
6
- - vendor/bundle/**/*
7
-
8
1
  # 80 is stifling, especially with a few levels of nesting before we even start.
9
2
  # So bump it to 100 to keep really long lines from creeping in.
10
3
  Metrics/LineLength:
11
- Enabled: false
12
4
  Max: 100
13
5
 
14
- Style/HashSyntax:
15
- Enabled: true
16
- EnforcedStyle: hash_rockets
6
+ Style/UseHashRocketsWithSymbolValues: false
7
+
8
+
data/CHANGELOG.markdown CHANGED
@@ -1,369 +1,11 @@
1
- # 2.6.10
1
+ # 2.2.0
2
2
 
3
- * Fix an edge case in JSON serialization (#360)
4
-
5
- # 2.6.9
6
-
7
- * Add `ssl_cert_file` config option (#352)
8
- * Improve sanitization of Postgres UPDATE SQL (#351)
9
- * Allow custom URL sanitization (#341)
10
-
11
- # 2.6.8
12
-
13
- * Lock rake version for 1.8.7 to older version (#329)
14
- * Delete unneeded .DS_Store file that snuck in (#334)
15
- * Fix typo in "queue_time_ms"
16
- * Fix Rails 6 deprecation warning at boot time (#337)
17
- * Fix partial naming on Rails 6.0 (#339)
18
- * Support Sidekiq 6.1 instrumentation (#340)
19
-
20
- # 2.6.7
21
-
22
- * Remove accidental call to `as_json`
23
-
24
- # 2.6.6
25
-
26
- * Add basic support for parsing Microsoft SQLServer queries (#317)
27
- * Refine Postgresql Sanitization with subqueries and JSON operations (#262)
28
-
29
- # 2.6.5
30
-
31
- * Add a tag to any requests that reach maximum number of spans (#316)
32
- * Update testing library Mocha (#315)
33
- * Fix case sensitivity mismatch in Job renaming (#314)
34
- * Add support for Sneakers 2.5 (#313)
35
- * Fix edge case with Resque instrumentation (#312)
36
- * Fix missing source code when used with BugSnag (#308)
37
-
38
- # 2.6.4
39
-
40
- * Add defensive check against a nil @address in Net/HTTP instruments (#306)
41
-
42
- # 2.6.3
43
-
44
- * Standardize Metadata with other language agents (#302)
45
- * Add Mongoid 7.x support (#295)
46
- * Add HTTP::Client support (#260)
47
-
48
- # 2.6.2
49
-
50
- * Fix Autoinstruments logging when running without ActiveSupport (#290)
51
- * Fix edge-case Autoinstruments syntax error (#287)
52
- * Fix invalid syntax for running on Ruby 1.8.7
53
-
54
- # 2.6.1
55
-
56
- * Logging total autoinstrumented spans and the ratio of significant to total spans (#283).
57
- * Added `autoinstruments_ignore` option (also #283).
58
-
59
- # 2.6.0
60
-
61
- * Autoinstruments (#247). Disabled by default. Set `auto_instruments: true` to enable.
62
-
63
- # 2.5.3
64
-
65
- * Add Que support (#265)
66
- * Add Memcached support (#279)
67
-
68
- # 2.5.2
69
-
70
- * Don't process limited layers in detailed traces (#268)
71
- * Fix OctoShark (and other gems which patch ActiveRecord) interaction (#217)
72
- * Legacy [Rails 2.3 fix for as_json](https://github.com/scoutapp/scout_apm_ruby/pull/276)
73
-
74
- # 2.5.1
75
-
76
- * Decrease timeline trace span limit to 1,500 to address [this bug](https://github.com/scoutapp/scout_apm_ruby/issues/267).
77
-
78
- # 2.5.0
79
-
80
- * Added timeline traces and an associated `timeline_traces: true` config option.
81
- * Increased timeline traces span limit to 2,500 from 500.
82
-
83
- # 2.4.24
84
-
85
- * Fix for prepending view instruments in the case of templates that lack a `virtual_path` (#257).
86
-
87
- # 2.4.23
88
-
89
- * Extend #251 to use prepend on all view instruments (#255)
90
-
91
- # 2.4.22
92
-
93
- * Support Rails 6.0 View Instruments (#251)
94
- * Update documentation URLs (#236)
95
-
96
- # 2.4.21
97
-
98
- * App & Background Integrations only install when needed (#228)
99
- * New Setting `collect_remote_ip`, to optionally disable automated capture of
100
- end-user IP Address. No change to default behavior.
101
- * Allow setting `compress_payload` option from ENV var (#234)
102
-
103
- # 2.4.20
104
-
105
- * `start_resque_server_instrument` option to allow disabling the WEBrick server
106
- component in custom installation scenarios
107
- * Allow setting `revision_sha` setting in YAML
108
-
109
- # 2.4.19
110
-
111
- * Fix disabled_instruments (#220)
112
-
113
- # 2.4.18
114
-
115
- * Add Shoryuken Support (#215)
116
- * Add Sneakers Support (#216)
117
-
118
- # 2.4.17
119
-
120
- * Renames SQL `BEGIN` and `COMMIT` statements from `SQL#other` to `SQL#begin` and `SQL#commit`, respectively.
121
- * Makes naming between transaction and database metrics consistent. Previously, database metrics lacking a provided ActiveRecord label were named `SQL#other`.
122
-
123
- # 2.4.16
124
-
125
- * Fix synchronization bug in Store (#205, PR #210)
126
-
127
- # 2.4.15
128
-
129
- * Fix bug that causes no data to be reported to Scout when DataDog is installed (#211)
130
- * Fix `NoMethodError for LayerChildrenSet` when `log_level: debug` in certain situations.
131
-
132
- # 2.4.14
133
-
134
- * Fix database connection issue when installed in an app also using the Textacular gem
135
-
136
- # 2.4.13
137
-
138
- * Incorporating total time consumed into transaction trace policy
139
-
140
- # 2.4.12
141
-
142
- * Calculates DelayedJob queue latency correctly when jobs are scheduled to run in the future
143
-
144
- # 2.4.11
145
-
146
- * Adds transaction + periodic reporting callback extension support
147
- * Use Module#prepend if available for ActiveRecord `exec_query` instrument
148
-
149
- # 2.4.10
150
-
151
- * Improve ActiveRecord instrumentation across Rails 3.2+, and adding support
152
- for the newly released Rails 5.2
153
-
154
- # 2.4.9
155
-
156
- * ScoutApm::Transaction#rename and #ignore API
157
- * Explicit custom instrumentation with ScoutApm::Tracer#instrument blocks,
158
- without needing to include a module
159
- * Quieter logging in normal startup cases
160
- * Upgraded testing infrastructure
161
-
162
- # 2.4.8
163
-
164
- * Fix issue with detailed middleware instrumentation
165
-
166
- # 2.4.7
167
-
168
- * Fix issue recording backtraces
169
-
170
- # 2.4.6
171
-
172
- * Fix an edge case for Resque instrumentation
173
-
174
- # 2.4.5
175
-
176
- * More robust installation of instruments at startup
177
- * Several (very) minor bug fixes
178
-
179
- # 2.4.4
180
-
181
- * Prevent agent from starting when monitor=false
182
- * Fix double-counting of HTTP requests when multiple http libraries are present
183
- * Fix an issue with Resque instrumentation
184
-
185
- # 2.4.3
186
-
187
- * Ensure a startup hook runs on forking webservers
188
-
189
- # 2.4.2
190
-
191
- * Fix shutdown hook for Passenger
192
-
193
- # 2.4.1
194
-
195
- * Fix logging on STDOUT only platforms (Heroku)
196
-
197
- # 2.4.0
198
-
199
- * Rework agent startup sequence
200
- * Install all background job instrumentations if you're running more than one
201
- * Capture longer individual SQL statements
202
- * Capture multiple SQL statements if multiple are run during a single AR call.
203
-
204
- # 2.3.5
205
-
206
- * More robust recovery from stale layaway files
207
- * Quiet logging when hitting unusual layaway file limits
208
- * Better naming for Sidekiq delayed method jobs
209
- * Webrick is only required if actually needed
210
-
211
- # 2.3.4
212
-
213
- * Capture 300 characters of a url from net/http and httpclient instruments (up from 100).
214
-
215
- # 2.3.3
216
-
217
- * Capture ActiveRecord calls that generate more complex queries
218
- * More aggressively determine names of complex queries (to determine "User/find", "Account/create" and similar)
219
- * Increases the maximum size of SQL queries that are sanitized to 16KB from 4 KB
220
- * Captures all SQL individual queries generated in a given AR call (previous only a single query was captured)
221
-
222
- # 2.3.2
223
-
224
- * More robust startup sequence when using `rails server` vs. directly launching an app server
225
- * Avoid incompatibility with 3rd party gems that aggressively obtain database connections
226
-
227
- # 2.3.1
228
-
229
- * Fix DevTrace bug
230
-
231
- # 2.3.0
232
-
233
- Note: ScoutApm Agent version 2.2.0 was the initial ScoutProf agent that was
234
- determined quickly to be a big enough change to warrant the move to 3.0. We are not
235
- reusing that version number to avoid confusion.
236
-
237
- * Deeper database query instrumentation. The agent now collects app-wide
238
- database usage on every call. This will allow you to better identify
239
- persistently slow queries, and capacity bottlenecks.
240
- * Optimize the approach used during recording each request to avoid unnecessary
241
- work, improving performance
242
-
243
- # 2.1.32
244
-
245
- * Better naming when using Resque + ActiveJob
246
- * Better naming when using Sidekiq + DelayedExtension
247
-
248
- # 2.1.31
249
-
250
- * Better detection of Resque queue names
251
- * Fix passing arguments through Active Record instrumentation. (Thanks to Nick Quaranto for providing the fix)
252
- * Stricter checks to prevent agent from starting in Rails console
253
-
254
- # 2.1.30
255
-
256
- * Add Resque support.
257
-
258
- # 2.1.29
259
-
260
- * Add `scm_subdirectory` option. Useful for when your app code does not live in your SCM root directory.
261
-
262
- # 2.1.28
263
-
264
- * Changes to app server load data
265
-
266
- # 2.1.27
267
-
268
- * Don't attempt to call `current_layer.type` on nil
269
-
270
- # 2.1.26
271
-
272
- * Bug fix [4b188d6](https://github.com/scoutapp/scout_apm_ruby/commit/4b188d698852c86b86d8768ea5b37d706ce544fe)
273
-
274
- # 2.1.25
275
-
276
- * Automatically instrument API and Metal controllers.
277
-
278
- # 2.1.24
279
-
280
- * Capture additional layers of application backtrace frames. (From 3 -> 8)
281
-
282
- # 2.1.23
283
-
284
- * Extend Mongoid instrumentation to 6.x
285
-
286
- # 2.1.22
287
-
288
- * Add DevTrace support for newest 4.2.x and 5.x versions of Rails
289
-
290
- # 2.1.21
291
-
292
- * Fix edge case, causing DevTrace to fail
293
- * Add debug tooling, allowing custom functions to be inserted into the agent at
294
- key points.
295
-
296
- # 2.1.20
297
-
298
- * Add a `detailed_middleware` boolean configuration option to capture
299
- per-middleware data, as opposed to the default of aggregating all middleware
300
- together. This has a small amount of additional overhead, approximately
301
- 10-15ms per request.
302
-
303
- # 2.1.19
304
-
305
- * Log all configuration settings at start when log level is debug
306
- * Tune DelayedJob class name detection
307
-
308
- # 2.1.18
309
-
310
- * Max layaway file threshold limit
311
-
312
- # 2.1.17
313
-
314
- * Additional logging around file system usage
315
-
316
- # 2.1.16
317
-
318
- * Extract the name correctly for DelayedJob workers run via ActiveJob
319
-
320
- # 2.1.15
321
-
322
- * Limit memory usage for very long running requests.
323
-
324
- # 2.1.14
325
-
326
- * Add TrackedRequest#ignore_request! to entirely ignore and stop capturing a
327
- certain request. Use in your code by calling:
328
- ScoutApm::RequestManager.lookup.ignore_request!
329
-
330
- # 2.1.13
331
-
332
- * Rework Delayed Job instrumentation to not interfere with other instruments.
333
-
334
- # 2.1.12
335
-
336
- * Revert 2.1.11's Delayed Job change - caused issues in a handful of environments
337
-
338
- # 2.1.11
339
-
340
- * Support alternate methods of launching Delayed Job
341
-
342
- # 2.1.10
343
-
344
- * Fix issue getting a default Application Name when it wasn't explicitly set
345
-
346
- # 2.1.9
347
-
348
- * Send raw histograms of response time, enabling more accurate 95th %iles
349
- * Raw histograms are used in Apdex calculations
350
- * Gzip payloads
351
- * Fix Mongoid (5.0) + Mongo (2.1) support
352
- * Initial Delayed Job support
353
- * Limit max metric size of a trace to 500.
354
-
355
-
356
- # 2.1.8
357
-
358
- * Adds Git revision detection, which is reported on app load and associated with transaction traces
359
-
360
- # 2.1.7
361
-
362
- * Fix allocations extension compilation on Ruby 1.8.7
3
+ * ScoutProf BETA
363
4
 
364
5
  # 2.1.6
365
6
 
366
7
  * Support older versions of Grape (0.10 onward)
8
+ * Fix issue with complex AR queries
367
9
  * Vendor rusage library
368
10
  * Fix double-exit that caused error messages when running under Passenger
369
11
 
@@ -738,7 +380,7 @@ Big set of features getting merged in for this release.
738
380
 
739
381
  # 0.1.3
740
382
 
741
- * Adds capacity calculation via "Instance/Capacity" metric.
383
+ * Adds capacity calculation via "Instance/Capacity" metric.
742
384
  * Tweaks tracing to still count a transaction if it results in a 500 error and includes it in accumulated time.
743
385
  * Adds per-transaction error tracking (ex: Errors/Controller/widgets/index)
744
386
 
data/Gemfile CHANGED
@@ -1,17 +1,4 @@
1
- source "https://rubygems.org"
1
+ source "http://rubygems.org"
2
2
 
3
3
  # Specify your gem's dependencies in scout_apm.gemspec
4
4
  gemspec
5
-
6
- # Pin development dependencies more conservatively for Ruby 1.8.7
7
- if RUBY_VERSION <= "1.8.7"
8
- gem "activesupport", "~> 3.2"
9
- gem "i18n", "~> 0.6.11"
10
- gem "pry", "~> 0.9.12"
11
- gem "rake", "~> 10.5"
12
- gem "minitest", "~> 5.11.3"
13
- elsif RUBY_VERSION <= "1.9.3"
14
- gem "rake", "~> 10.5"
15
- else
16
- gem "rake", ">= 12.3.3"
17
- end
data/README.markdown CHANGED
@@ -1,32 +1,14 @@
1
- # ScoutApm Ruby Agent
1
+ # ScoutApm
2
2
 
3
- [![Build Status](https://travis-ci.org/scoutapp/scout_apm_ruby.svg?branch=master)](https://travis-ci.org/scoutapp/scout_apm_ruby)
4
-
5
- A Ruby gem for detailed Rails application performance monitoring 📈. Metrics and transaction traces are
6
- reported to [Scout](https://scoutapp.com), a hosted application monitoring
7
- service.
8
-
9
- ## What's the special sauce? 🤔
10
-
11
- The Scout agent is engineered to do some wonderful things:
12
-
13
- * A unique focus on identifying those hard-to-investigate outliers like memory bloat, N+1s, and user-specific problems. [See an example workflow](http://scoutapp.com/newrelic-alternative).
14
- * [Low-overhead](http://blog.scoutapp.com/articles/2016/02/07/overhead-benchmarks-new-relic-vs-scout)
15
- * View your performance metrics during development with [DevTrace](https://docs.scoutapm.com/#devtrace) and in production via [server_timing](https://github.com/scoutapp/ruby_server_timing).
16
- * Production-Safe profiling of custom code via [ScoutProf](https://docs.scoutapm.com/#scoutprof) (BETA).
3
+ A Ruby gem for detailed Rails application performance analysis. Metrics are reported to [Scout](https://scoutapp.com), a hosted application monitoring service.
17
4
 
18
5
  ## Getting Started
19
6
 
20
- Add the gem to your Gemfile
21
-
22
- gem 'scout_apm'
7
+ Install the gem:
23
8
 
24
- Update your Gemfile
25
-
26
- bundle install
27
-
28
- Signup for a [Scout](https://scoutapm.com) account and put the provided
29
- config file at `RAILS_ROOT/config/scout_apm.yml`.
9
+ gem install scout_apm
10
+
11
+ Signup for a [Scout](https://apm.scoutapp.com) account and copy the config file to `RAILS_ROOT/config/scout_apm.yml`.
30
12
 
31
13
  Your config file should look like:
32
14
 
@@ -35,39 +17,12 @@ Your config file should look like:
35
17
  key: YOUR_APPLICATION_KEY
36
18
  monitor: true
37
19
 
38
- test:
39
- monitor: false
40
-
41
20
  production:
42
21
  <<: *defaults
43
22
 
44
- ## DevTrace Quickstart
45
-
46
- To use DevTrace, our free, no-signup, in-browser development profiler:
47
-
48
- 1. Add the gem to your Gemfile:
49
-
50
- ```ruby
51
- # Gemfile
52
- gem 'scout_apm'
53
- ```
54
-
55
- 2. Start your Rails app with the SCOUT_DEV_TRACE environment variable:
56
-
57
- ```
58
- SCOUT_DEV_TRACE=true rails server
59
- ```
60
-
61
- ## How to test gem locally
62
-
63
- * Point your gemfile at your local checkout: `gem 'scout_apm', path: '/path/to/scout_apm_ruby`
64
- * Compile native code: `cd /path/to/scout_apm_ruby && bundle exec rake compile`
65
-
66
-
67
23
  ## Docs
68
24
 
69
- For the complete list of supported frameworks, Rubies, configuration options
70
- and more, see our [help site](https://docs.scoutapm.com/).
25
+ For the complete list of supported frameworks, Rubies, etc, see our [help site](http://help.apm.scoutapp.com/).
71
26
 
72
27
  ## Help
73
28
 
data/Rakefile CHANGED
@@ -21,5 +21,6 @@ end
21
21
  # Rake Compiler
22
22
  require 'rake/extensiontask'
23
23
  Rake::ExtensionTask.new('allocations')
24
+ Rake::ExtensionTask.new('stacks')
24
25
  Rake::ExtensionTask.new('rusage')
25
26
 
@@ -1,14 +1,10 @@
1
- #ifdef HAVE_RUBY_RUBY_H
2
1
  #include <ruby/ruby.h>
3
- #else // Ruby <= 1.8.7
4
- #include <ruby.h>
5
- #endif
6
2
 
7
3
  VALUE mScoutApm;
8
4
  VALUE mInstruments;
9
5
  VALUE cAllocations;
10
6
 
11
- #if defined(RUBY_INTERNAL_EVENT_NEWOBJ) && !defined(_WIN32)
7
+ #ifdef RUBY_INTERNAL_EVENT_NEWOBJ
12
8
 
13
9
  #include <sys/resource.h> // is this needed?
14
10
  #include <sys/time.h>
@@ -56,7 +52,6 @@ void Init_allocations()
56
52
  mInstruments = rb_define_module_under(mScoutApm, "Instruments");
57
53
  cAllocations = rb_define_class_under(mInstruments, "Allocations", rb_cObject);
58
54
  rb_define_singleton_method(cAllocations, "count", get_allocation_count, 0);
59
- rb_define_singleton_method(cAllocations, "count", get_allocation_count, 0);
60
55
  rb_define_const(cAllocations, "ENABLED", Qtrue);
61
56
  Init_hooks(mScoutApm);
62
57
  }
@@ -79,7 +74,6 @@ void Init_allocations()
79
74
  mInstruments = rb_define_module_under(mScoutApm, "Instruments");
80
75
  cAllocations = rb_define_class_under(mInstruments, "Allocations", rb_cObject);
81
76
  rb_define_singleton_method(cAllocations, "count", get_allocation_count, 0);
82
- rb_define_singleton_method(cAllocations, "count", get_allocation_count, 0);
83
77
  rb_define_const(cAllocations, "ENABLED", Qfalse);
84
78
  Init_hooks(mScoutApm);
85
79
  }
@@ -1,4 +1,3 @@
1
1
  require 'mkmf'
2
2
 
3
- have_header("ruby/ruby.h") # Needed to check for Ruby <= 1.8.7
4
3
  create_makefile('allocations')
data/ext/rusage/rusage.c CHANGED
@@ -1,35 +1,10 @@
1
1
  // VERSION = "x.y.z"
2
2
  #include <ruby.h>
3
- #ifdef _WIN32
4
- #define RUSAGE_SELF 0
5
- #define RUSAGE_CHILDREN 0
6
- #else
7
3
  #include <sys/resource.h>
8
- #endif
9
4
 
10
5
  VALUE v_usage_struct;
11
6
 
12
7
  static VALUE do_rusage_get(int who){
13
- #ifdef _WIN32
14
- return rb_struct_new(v_usage_struct,
15
- rb_float_new(0),
16
- rb_float_new(0),
17
- LONG2NUM(0),
18
- LONG2NUM(0),
19
- LONG2NUM(0),
20
- LONG2NUM(0),
21
- LONG2NUM(0),
22
- LONG2NUM(0),
23
- LONG2NUM(0),
24
- LONG2NUM(0),
25
- LONG2NUM(0),
26
- LONG2NUM(0),
27
- LONG2NUM(0),
28
- LONG2NUM(0),
29
- LONG2NUM(0),
30
- LONG2NUM(0)
31
- );
32
- #else // _WIN32
33
8
  struct rusage r;
34
9
  int ret;
35
10
 
@@ -55,7 +30,6 @@ static VALUE do_rusage_get(int who){
55
30
  LONG2NUM(r.ru_nvcsw),
56
31
  LONG2NUM(r.ru_nivcsw)
57
32
  );
58
- #endif // _WIN32
59
33
  }
60
34
 
61
35
  static VALUE rusage_get(int argc, VALUE* argv, VALUE mod){
@@ -0,0 +1,37 @@
1
+ begin
2
+ require 'mkmf'
3
+ can_compile = true
4
+ rescue Exception
5
+ # This will appear only in verbose mode.
6
+ $stderr.puts "Could not require 'mkmf'. Not fatal, the Stacks extension is optional."
7
+ end
8
+
9
+ can_compile &&= have_func('rb_postponed_job_register_one')
10
+ can_compile &&= have_func('rb_profile_frames')
11
+ can_compile &&= have_func('rb_profile_frame_absolute_path')
12
+ can_compile &&= have_func('rb_profile_frame_label')
13
+ can_compile &&= have_func('rb_profile_frame_classpath')
14
+
15
+ # Explicitly link against librt
16
+ if have_macro('__linux__')
17
+ can_compile &&= have_library('rt') # for timer_create, timer_settime
18
+ end
19
+
20
+ # Pick the atomics implementation
21
+ has_atomics_header = have_header("stdatomic.h")
22
+ if has_atomics_header
23
+ $defs.push "-DSCOUT_USE_NEW_ATOMICS"
24
+ else
25
+ $defs.push "-DSCOUT_USE_OLD_ATOMICS"
26
+ end
27
+
28
+ if can_compile
29
+ create_makefile('stacks')
30
+ else
31
+ # Create a dummy Makefile, to satisfy Gem::Installer#install
32
+ mfile = open("Makefile", "wb")
33
+ mfile.puts '.PHONY: install'
34
+ mfile.puts 'install:'
35
+ mfile.puts "\t" + '@echo "Stack extension not installed, skipping."'
36
+ mfile.close
37
+ end