newrelic_rpm 2.13.2 → 2.13.3.beta

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of newrelic_rpm might be problematic. Click here for more details.

Files changed (92) hide show
  1. data/CHANGELOG +18 -0
  2. data/LICENSE +1 -1
  3. data/README.rdoc +10 -5
  4. data/lib/conditional_vendored_metric_parser.rb +5 -0
  5. data/lib/new_relic/agent.rb +0 -1
  6. data/lib/new_relic/agent/agent.rb +1 -1
  7. data/lib/new_relic/agent/error_collector.rb +2 -0
  8. data/lib/new_relic/agent/instrumentation/data_mapper.rb +170 -47
  9. data/lib/new_relic/agent/instrumentation/memcache.rb +3 -1
  10. data/lib/new_relic/agent/instrumentation/metric_frame.rb +1 -1
  11. data/lib/new_relic/agent/instrumentation/rails3/action_controller.rb +6 -0
  12. data/lib/new_relic/agent/instrumentation/sinatra.rb +4 -3
  13. data/lib/new_relic/agent/stats_engine/metric_stats.rb +134 -98
  14. data/lib/new_relic/commands/install.rb +10 -0
  15. data/lib/new_relic/control.rb +13 -0
  16. data/lib/new_relic/control/configuration.rb +1 -1
  17. data/lib/new_relic/control/frameworks/rails.rb +9 -5
  18. data/lib/new_relic/control/frameworks/rails3.rb +3 -7
  19. data/lib/new_relic/control/instrumentation.rb +2 -2
  20. data/lib/new_relic/delayed_job_injection.rb +1 -1
  21. data/lib/new_relic/rack/developer_mode.rb +1 -1
  22. data/lib/new_relic/recipes.rb +1 -1
  23. data/lib/new_relic/transaction_analysis.rb +1 -1
  24. data/lib/new_relic/transaction_sample.rb +3 -1
  25. data/lib/new_relic/version.rb +2 -2
  26. data/newrelic_rpm.gemspec +50 -19
  27. data/test/new_relic/agent/memcache_instrumentation_test.rb +29 -25
  28. data/ui/helpers/developer_mode_helper.rb +1 -11
  29. data/ui/views/newrelic/_segment.rhtml +0 -1
  30. data/ui/views/newrelic/_segment_row.rhtml +1 -3
  31. data/ui/views/newrelic/index.rhtml +12 -0
  32. data/ui/views/newrelic/threads.rhtml +8 -7
  33. data/vendor/gems/metric_parser-0.1.0.pre1/LICENSE +0 -0
  34. data/vendor/gems/metric_parser-0.1.0.pre1/README +0 -0
  35. data/vendor/gems/metric_parser-0.1.0.pre1/lib/metric_parser.rb +1 -0
  36. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser.rb +64 -0
  37. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/action_mailer.rb +14 -0
  38. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/active_merchant.rb +31 -0
  39. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/active_record.rb +33 -0
  40. data/{lib → vendor/gems/metric_parser-0.1.0.pre1/lib}/new_relic/metric_parser/apdex.rb +12 -11
  41. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/background_transaction.rb +7 -0
  42. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/client.rb +46 -0
  43. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/controller.rb +67 -0
  44. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/controller_cpu.rb +43 -0
  45. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/controller_ext.rb +17 -0
  46. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/database.rb +48 -0
  47. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/database_pool.rb +24 -0
  48. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/dot_net.rb +28 -0
  49. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/dot_net_parser.rb +17 -0
  50. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/errors.rb +11 -0
  51. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/external.rb +55 -0
  52. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/frontend.rb +40 -0
  53. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/gc.rb +20 -0
  54. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/hibernate_session.rb +7 -0
  55. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/java.rb +31 -0
  56. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/java_parser.rb +17 -0
  57. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/jsp.rb +34 -0
  58. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/jsp_tag.rb +7 -0
  59. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/mem_cache.rb +55 -0
  60. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/metric_parser.rb +122 -0
  61. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/orm.rb +27 -0
  62. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/other_transaction.rb +40 -0
  63. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet.rb +7 -0
  64. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet_context_listener.rb +7 -0
  65. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet_filter.rb +7 -0
  66. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/solr.rb +27 -0
  67. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/solr_request_handler.rb +15 -0
  68. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/spring.rb +54 -0
  69. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/spring_controller.rb +6 -0
  70. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/spring_view.rb +6 -0
  71. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/struts_action.rb +20 -0
  72. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/struts_result.rb +20 -0
  73. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/version.rb +5 -0
  74. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/view.rb +66 -0
  75. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/web_frontend.rb +18 -0
  76. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/web_service.rb +14 -0
  77. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/web_transaction.rb +133 -0
  78. metadata +88 -39
  79. data/lib/new_relic/metric_parser.rb +0 -136
  80. data/lib/new_relic/metric_parser/action_mailer.rb +0 -9
  81. data/lib/new_relic/metric_parser/active_merchant.rb +0 -26
  82. data/lib/new_relic/metric_parser/active_record.rb +0 -28
  83. data/lib/new_relic/metric_parser/controller.rb +0 -62
  84. data/lib/new_relic/metric_parser/controller_cpu.rb +0 -38
  85. data/lib/new_relic/metric_parser/errors.rb +0 -6
  86. data/lib/new_relic/metric_parser/external.rb +0 -50
  87. data/lib/new_relic/metric_parser/mem_cache.rb +0 -50
  88. data/lib/new_relic/metric_parser/other_transaction.rb +0 -36
  89. data/lib/new_relic/metric_parser/view.rb +0 -61
  90. data/lib/new_relic/metric_parser/web_frontend.rb +0 -14
  91. data/lib/new_relic/metric_parser/web_service.rb +0 -9
  92. data/test/new_relic/metric_parser_test.rb +0 -226
@@ -0,0 +1,27 @@
1
+ module NewRelic
2
+ module MetricParser
3
+ class ORM < NewRelic::MetricParser::MetricParser
4
+ module Hibernate
5
+ def self.extended(base)
6
+ if base.segments.length == 4
7
+ base.extend JavaParser
8
+ def base.full_class_name
9
+ segment_2
10
+ end
11
+ def base.method_name
12
+ segment_3
13
+ end
14
+ end
15
+ end
16
+ end
17
+
18
+ def initialize(name)
19
+ super
20
+
21
+ if segment_1 == "Hibernate"
22
+ self.extend NewRelic::MetricParser::ORM::Hibernate
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,40 @@
1
+ require 'new_relic/metric_parser'
2
+ # OtherTransaction metrics must have at least three segments: /OtherTransaction/<task>/*
3
+ # Task is "Background", "Resque", "DelayedJob" etc.
4
+ module NewRelic
5
+ module MetricParser
6
+ class OtherTransaction < NewRelic::MetricParser::MetricParser
7
+
8
+ def is_transaction?
9
+ true
10
+ end
11
+ def task
12
+ segments[1]
13
+ end
14
+
15
+ def developer_name
16
+ segments[2..-1].join(NewRelic::MetricParser::MetricParser::SEPARATOR)
17
+ end
18
+
19
+ def short_name
20
+ developer_name
21
+ end
22
+
23
+ def drilldown_url(metric_id)
24
+ {:controller => '/v2/background_tasks', :action => 'index', :task => task, :anchor => "id=#{metric_id}"}
25
+ end
26
+
27
+ def path
28
+ segments[2..-1].join "/"
29
+ end
30
+
31
+ def summary_metrics
32
+ if segments.size > 2
33
+ %W[OtherTransaction/#{task}/all OtherTransaction/all]
34
+ else
35
+ []
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,7 @@
1
+ require 'new_relic/metric_parser/java'
2
+ class NewRelic::MetricParser::Servlet < NewRelic::MetricParser::Java
3
+
4
+ def call_rate_suffix
5
+ 'cpm'
6
+ end
7
+ end
@@ -0,0 +1,7 @@
1
+ require 'new_relic/metric_parser/java'
2
+ class NewRelic::MetricParser::ServletContextListener < NewRelic::MetricParser::Java
3
+
4
+ def call_rate_suffix
5
+ 'cpm'
6
+ end
7
+ end
@@ -0,0 +1,7 @@
1
+ require 'new_relic/metric_parser/java'
2
+ class NewRelic::MetricParser::ServletFilter < NewRelic::MetricParser::Java
3
+
4
+ def call_rate_suffix
5
+ 'cpm'
6
+ end
7
+ end
@@ -0,0 +1,27 @@
1
+ class NewRelic::MetricParser::Solr < NewRelic::MetricParser::MetricParser
2
+
3
+ def short_name
4
+ if segments[1] == "org.apache.solr.search.SolrIndexSearcher"
5
+ "SolrIndexSearcher"
6
+ elsif segments[1] =~ /org\.apache\.solr\.handler\.component/
7
+ segments[1].split(".")[-1]
8
+ else
9
+ super
10
+ end
11
+ end
12
+
13
+ def legend_name
14
+ if all?
15
+ 'Solr'
16
+ else
17
+ super
18
+ end
19
+ end
20
+
21
+ def category; 'Solr Query'; end
22
+
23
+ private
24
+ def all?
25
+ name == Metric::SOLR_ALL_WEB
26
+ end
27
+ end
@@ -0,0 +1,15 @@
1
+ #require 'new_relic/metric_parser/java'
2
+ class NewRelic::MetricParser::SolrRequestHandler < NewRelic::MetricParser::MetricParser
3
+
4
+ def short_name
5
+ if segments[1] == "org.apache.solr.handler.XmlUpdateRequestHandler"
6
+ "UpdateProcessor"
7
+ else
8
+ super
9
+ end
10
+ end
11
+
12
+ def call_rate_suffix
13
+ 'cpm'
14
+ end
15
+ end
@@ -0,0 +1,54 @@
1
+ class NewRelic::MetricParser::Spring < NewRelic::MetricParser::MetricParser
2
+ def initialize(name)
3
+ super
4
+
5
+ if segment_1 == 'Java'
6
+ self.extend JavaParser
7
+ end
8
+ =begin
9
+ case segment_1
10
+ when 'Controller'
11
+ self.extend NewRelic::MetricParser::Spring::Controller
12
+ when 'View'
13
+ self.extend NewRelic::MetricParser::Spring::View
14
+ end
15
+ =end
16
+ end
17
+
18
+
19
+ def pie_chart_label
20
+ short_name
21
+ end
22
+
23
+ def tooltip_name
24
+ developer_name
25
+ end
26
+
27
+ def component_type
28
+ 'Spring'
29
+ end
30
+
31
+ def short_name
32
+ component_type + ' ' + developer_name
33
+ end
34
+
35
+ def developer_name
36
+ '/' + segments[1..-1].join(SEPARATOR)
37
+ end
38
+
39
+ module JavaParser
40
+ def developer_name
41
+ "#{segment_2}.#{segment_3}()"
42
+ end
43
+
44
+ def class_name_without_package
45
+ segment_2 =~ /(.*\.)(.*)$/ ? $2 : segment_2
46
+ end
47
+
48
+ # class name with/out package name and method name
49
+ def short_name
50
+ "#{component_type} #{class_name_without_package}.#{segment_3}()"
51
+ end
52
+
53
+ end
54
+ end
@@ -0,0 +1,6 @@
1
+ require 'new_relic/metric_parser/spring'
2
+ class NewRelic::MetricParser::SpringController < NewRelic::MetricParser::Spring
3
+ def component_type
4
+ "Controller"
5
+ end
6
+ end
@@ -0,0 +1,6 @@
1
+ require 'new_relic/metric_parser/spring'
2
+ class NewRelic::MetricParser::SpringView < NewRelic::MetricParser::Spring
3
+ def component_type
4
+ "View"
5
+ end
6
+ end
@@ -0,0 +1,20 @@
1
+ require 'new_relic/metric_parser/java_parser'
2
+ module NewRelic
3
+ module MetricParser
4
+ class StrutsAction < NewRelic::MetricParser::MetricParser
5
+ include NewRelic::MetricParser::JavaParser
6
+
7
+ def method_name
8
+ "execute"
9
+ end
10
+
11
+ def full_class_name
12
+ segment_1
13
+ end
14
+
15
+ def call_rate_suffix
16
+ 'cpm'
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,20 @@
1
+ require 'new_relic/metric_parser/java_parser'
2
+ module NewRelic
3
+ module MetricParser
4
+ class StrutsResult < NewRelic::MetricParser::MetricParser
5
+ include JavaParser
6
+
7
+ def method_name
8
+ "execute"
9
+ end
10
+
11
+ def full_class_name
12
+ segment_1
13
+ end
14
+
15
+ def call_rate_suffix
16
+ 'cpm'
17
+ end
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,5 @@
1
+ module NewRelic
2
+ module MetricParser
3
+ VERSION = "0.1.0.pre1"
4
+ end
5
+ end
@@ -0,0 +1,66 @@
1
+ require 'new_relic/metric_parser'
2
+ module NewRelic
3
+ module MetricParser
4
+ class View < NewRelic::MetricParser::MetricParser
5
+ def is_view?; true; end
6
+
7
+ def is_render?
8
+ segments.last == "Rendering"
9
+ end
10
+ def is_compiler?
11
+ segments.last == "Compile"
12
+ end
13
+ def pie_chart_label
14
+ case segments.last
15
+ when "Rendering"
16
+ "#{file_name(segments[-2])} Template"
17
+ when "Partial"
18
+ "#{file_name(segments[-2])} Partial"
19
+ when ".rhtml Processing"
20
+ "ERB compilation"
21
+ else
22
+ segments[1..-1]
23
+ end
24
+ end
25
+ def template_label
26
+ case segments.last
27
+ when "Rendering"
28
+ "#{file_name(segments[1..-2].join(NewRelic::MetricParser::MetricParser::SEPARATOR))} Template"
29
+ when "Partial"
30
+ "#{file_name(segments[1..-2].join(NewRelic::MetricParser::MetricParser::SEPARATOR))} Partial"
31
+ when ".rhtml Processing"
32
+ "ERB compilation"
33
+ else
34
+ segments[1..-1].join("/")
35
+ end
36
+ end
37
+
38
+ def short_name
39
+ segments[1..-2].join(NewRelic::MetricParser::MetricParser::SEPARATOR)
40
+ end
41
+
42
+ def controller_name
43
+ template_label
44
+ end
45
+
46
+ def action_name
47
+ # Strip the extension
48
+ segments[-2].gsub(/\..*$/, "")
49
+ end
50
+
51
+ def developer_name
52
+ template_label
53
+ end
54
+
55
+ def url
56
+ '/' + file_name(segments[1..-2].join('/'))
57
+ end
58
+ private
59
+ def file_name(path)
60
+ label = path.gsub /\.html\.rhtml/, '.rhtml'
61
+ label = segments[1] if label.empty?
62
+ label
63
+ end
64
+ end
65
+ end
66
+ end
@@ -0,0 +1,18 @@
1
+ require 'new_relic/metric_parser'
2
+ # The metric where the mongrel queue time is stored
3
+ module NewRelic
4
+ module MetricParser
5
+ class WebFrontend < NewRelic::MetricParser::MetricParser
6
+ def short_name
7
+ if segments.last == 'Average Queue Time'
8
+ 'Mongrel Average Queue Time'
9
+ else
10
+ super
11
+ end
12
+ end
13
+ def legend_name
14
+ 'Mongrel Wait'
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,14 @@
1
+ require 'new_relic/metric_parser'
2
+ module NewRelic
3
+ module MetricParser
4
+ class WebService < NewRelic::MetricParser::MetricParser
5
+ def is_web_service?
6
+ segments[1] != 'Soap' && segments[1] != 'Xml Rpc'
7
+ end
8
+
9
+ def webservice_call_rate_suffix
10
+ 'rpm'
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,133 @@
1
+ class NewRelic::MetricParser::WebTransaction < NewRelic::MetricParser::MetricParser
2
+
3
+ def is_web_transaction?; true; end
4
+ def is_transaction?; true; end
5
+
6
+ module Controller
7
+ def category; 'Controller'; end
8
+ # If the controller name segments look like a file path, convert it to the controller
9
+ # class name. If it begins with a capital letter, assume it's already a class name
10
+ def controller_name
11
+ path = segments[2..-2].join('/')
12
+ path < 'a' ? path : camelize(path)+"Controller"
13
+ end
14
+
15
+ def action_name
16
+ segments[-1]
17
+ end
18
+
19
+ def developer_name
20
+ if action_name
21
+ "#{controller_name}##{action_name}"
22
+ else
23
+ controller_name
24
+ end
25
+ end
26
+ def short_name
27
+ developer_name
28
+
29
+ end
30
+
31
+ private
32
+ # Wow, ugliness. Ganked from Rails to make metric parser rails-free
33
+ def camelize(str)
34
+ str.to_s.gsub(/\/(.?)/) { "::#{$1.upcase}" }.gsub(/(?:^|_)(.)/) { $1.upcase }
35
+ end
36
+ end
37
+
38
+ # Like a controller but 2nd segment is always full class name,
39
+ # and 3rd segment (optional) is the action name
40
+ module Task
41
+ include Controller
42
+ def is_web_transaction?; false; end
43
+ def category; 'Task'; end
44
+ def action_name; segments[3]; end
45
+ def controller_name; segments[2]; end
46
+ end
47
+
48
+ module Rack
49
+ include Task
50
+
51
+ def is_web_transaction?; true; end
52
+ def category; 'Rack App'; end
53
+ end
54
+
55
+ module Spring
56
+ def category; 'Spring Transaction'; end
57
+ end
58
+
59
+ module SpringView
60
+ def is_web_transaction?; true; end
61
+ def category; 'Spring View'; end
62
+ end
63
+
64
+ module SpringController
65
+ def is_web_transaction?; true; end
66
+ def category; 'Spring Controller'; end
67
+ end
68
+
69
+ module Solr
70
+ def category; 'Solr Request'; end
71
+ end
72
+
73
+ module CXF
74
+ def category; 'CXF Transaction'; end
75
+ end
76
+
77
+ module Pattern
78
+ def category;'Pattern';end
79
+ def developer_name
80
+ "#{category}: #{pattern}"
81
+ end
82
+ def pattern
83
+ segments[2..-1].join('/')
84
+ end
85
+ def short_name
86
+ pattern
87
+ end
88
+ end
89
+
90
+ module Sinatra
91
+ include Pattern
92
+ def is_web_transaction?; true; end
93
+ def category; 'Sinatra'; end
94
+ end
95
+
96
+ def initialize(name)
97
+ super
98
+ if %w[Sinatra Spring SpringController SpringView Solr CXF Task Pattern Rack Controller].include?(segment_1)
99
+ self.extend NewRelic::MetricParser::WebTransaction.const_get(segment_1)
100
+ end
101
+ end
102
+
103
+ def developer_name
104
+ url
105
+ end
106
+
107
+ def short_name
108
+ if segments.length > 2
109
+ developer_name
110
+ else
111
+ 'All Web Transactions'
112
+ end
113
+ end
114
+
115
+ def url
116
+ '/' + segments[2..-1].join('/')
117
+ end
118
+
119
+ # this is used to match transaction traces to controller actions.
120
+ # TT's don't have a preceding slash :P
121
+ def tt_path
122
+ segments[2..-1].join('/')
123
+ end
124
+
125
+ def call_rate_suffix
126
+ 'rpm'
127
+ end
128
+
129
+ # default to v2 Web Transactions tab
130
+ def drilldown_url(metric_id)
131
+ {:controller => '/v2/transactions', :action => 'index', :anchor => "id=#{metric_id}"}
132
+ end
133
+ end