Mercurial > hg > truffle
annotate src/share/vm/services/diagnosticCommand.hpp @ 7956:16fb9f942703
6479360: PrintClassHistogram improvements
Summary: jcmd <pid> GC.class_stats (UnlockDiagnosticVMOptions)
Reviewed-by: coleenp, hseigel, sla, acorn
Contributed-by: ioi.lam@oracle.com
author | acorn |
---|---|
date | Fri, 25 Jan 2013 15:06:18 -0500 |
parents | fb19af007ffc |
children | 8f696cf1a0fb |
rev | line source |
---|---|
4133 | 1 /* |
7956 | 2 * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. |
4133 | 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 * | |
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | |
20 * or visit www.oracle.com if you need additional information or have any | |
21 * questions. | |
22 * | |
23 */ | |
24 | |
25 #ifndef SHARE_VM_SERVICES_DIAGNOSTICCOMMAND_HPP | |
26 #define SHARE_VM_SERVICES_DIAGNOSTICCOMMAND_HPP | |
27 | |
28 #include "runtime/arguments.hpp" | |
29 #include "classfile/vmSymbols.hpp" | |
30 #include "utilities/ostream.hpp" | |
31 #include "runtime/vm_version.hpp" | |
32 #include "runtime/vmThread.hpp" | |
33 #include "runtime/os.hpp" | |
34 #include "services/diagnosticArgument.hpp" | |
35 #include "services/diagnosticCommand.hpp" | |
36 #include "services/diagnosticFramework.hpp" | |
4851
a42c07c38c47
7132515: Add dcmd to manage UnlockingCommercialFeature flag
dsamersoff
parents:
4773
diff
changeset
|
37 #include "services/diagnosticCommand_ext.hpp" |
4133 | 38 |
4773 | 39 class HelpDCmd : public DCmdWithParser { |
4133 | 40 protected: |
41 DCmdArgument<bool> _all; | |
42 DCmdArgument<char*> _cmd; | |
43 public: | |
44 HelpDCmd(outputStream* output, bool heap); | |
45 static const char* name() { return "help"; } | |
46 static const char* description() { | |
47 return "For more information about a specific command use 'help <command>'. " | |
48 "With no argument this will show a list of available commands. " | |
49 "'help all' will show help for all commands."; | |
50 } | |
6202
5a1f452f8f90
7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents:
5895
diff
changeset
|
51 static const char* impact() { return "Low"; } |
4133 | 52 static int num_arguments(); |
53 virtual void execute(TRAPS); | |
54 }; | |
55 | |
56 class VersionDCmd : public DCmd { | |
57 public: | |
58 VersionDCmd(outputStream* output, bool heap) : DCmd(output,heap) { } | |
59 static const char* name() { return "VM.version"; } | |
60 static const char* description() { | |
61 return "Print JVM version information."; | |
62 } | |
6202
5a1f452f8f90
7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents:
5895
diff
changeset
|
63 static const char* impact() { return "Low"; } |
4133 | 64 static int num_arguments() { return 0; } |
4773 | 65 virtual void execute(TRAPS); |
66 }; | |
67 | |
68 class CommandLineDCmd : public DCmd { | |
69 public: | |
70 CommandLineDCmd(outputStream* output, bool heap) : DCmd(output, heap) { } | |
71 static const char* name() { return "VM.command_line"; } | |
72 static const char* description() { | |
73 return "Print the command line used to start this VM instance."; | |
74 } | |
6202
5a1f452f8f90
7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents:
5895
diff
changeset
|
75 static const char* impact() { return "Low"; } |
4773 | 76 static int num_arguments() { return 0; } |
77 virtual void execute(TRAPS) { | |
78 Arguments::print_on(_output); | |
79 } | |
80 }; | |
81 | |
82 // See also: get_system_properties in attachListener.cpp | |
83 class PrintSystemPropertiesDCmd : public DCmd { | |
84 public: | |
85 PrintSystemPropertiesDCmd(outputStream* output, bool heap) : DCmd(output, heap) { } | |
86 static const char* name() { return "VM.system_properties"; } | |
87 static const char* description() { | |
88 return "Print system properties."; | |
89 } | |
90 static const char* impact() { | |
6202
5a1f452f8f90
7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents:
5895
diff
changeset
|
91 return "Low"; |
4773 | 92 } |
93 static int num_arguments() { return 0; } | |
94 virtual void execute(TRAPS); | |
95 }; | |
96 | |
97 // See also: print_flag in attachListener.cpp | |
98 class PrintVMFlagsDCmd : public DCmdWithParser { | |
99 protected: | |
100 DCmdArgument<bool> _all; | |
101 public: | |
102 PrintVMFlagsDCmd(outputStream* output, bool heap); | |
103 static const char* name() { return "VM.flags"; } | |
104 static const char* description() { | |
105 return "Print VM flag options and their current values."; | |
106 } | |
107 static const char* impact() { | |
6202
5a1f452f8f90
7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents:
5895
diff
changeset
|
108 return "Low"; |
4773 | 109 } |
110 static int num_arguments(); | |
111 virtual void execute(TRAPS); | |
112 }; | |
113 | |
114 class VMUptimeDCmd : public DCmdWithParser { | |
115 protected: | |
116 DCmdArgument<bool> _date; | |
117 public: | |
118 VMUptimeDCmd(outputStream* output, bool heap); | |
119 static const char* name() { return "VM.uptime"; } | |
120 static const char* description() { | |
121 return "Print VM uptime."; | |
122 } | |
123 static const char* impact() { | |
6202
5a1f452f8f90
7178703: Fix handling of quoted arguments and better error messages in dcmd
sla
parents:
5895
diff
changeset
|
124 return "Low"; |
4773 | 125 } |
126 static int num_arguments(); | |
4133 | 127 virtual void execute(TRAPS); |
4773 | 128 }; |
129 | |
130 class SystemGCDCmd : public DCmd { | |
131 public: | |
132 SystemGCDCmd(outputStream* output, bool heap) : DCmd(output, heap) { } | |
133 static const char* name() { return "GC.run"; } | |
134 static const char* description() { | |
135 return "Call java.lang.System.gc()."; | |
136 } | |
137 static const char* impact() { | |
138 return "Medium: Depends on Java heap size and content."; | |
139 } | |
140 static int num_arguments() { return 0; } | |
141 virtual void execute(TRAPS); | |
142 }; | |
143 | |
144 class RunFinalizationDCmd : public DCmd { | |
145 public: | |
146 RunFinalizationDCmd(outputStream* output, bool heap) : DCmd(output, heap) { } | |
147 static const char* name() { return "GC.run_finalization"; } | |
148 static const char* description() { | |
149 return "Call java.lang.System.runFinalization()."; | |
150 } | |
151 static const char* impact() { | |
152 return "Medium: Depends on Java content."; | |
153 } | |
154 static int num_arguments() { return 0; } | |
155 virtual void execute(TRAPS); | |
156 }; | |
157 | |
6854
fb19af007ffc
7189254: Change makefiles for more flexibility to override defaults
jprovino
parents:
6202
diff
changeset
|
158 #if INCLUDE_SERVICES // Heap dumping supported |
4773 | 159 // See also: dump_heap in attachListener.cpp |
160 class HeapDumpDCmd : public DCmdWithParser { | |
161 protected: | |
162 DCmdArgument<char*> _filename; | |
163 DCmdArgument<bool> _all; | |
164 public: | |
165 HeapDumpDCmd(outputStream* output, bool heap); | |
166 static const char* name() { | |
167 return "GC.heap_dump"; | |
168 } | |
169 static const char* description() { | |
170 return "Generate a HPROF format dump of the Java heap."; | |
171 } | |
172 static const char* impact() { | |
173 return "High: Depends on Java heap size and content. " | |
174 "Request a full GC unless the '-all' option is specified."; | |
175 } | |
176 static int num_arguments(); | |
177 virtual void execute(TRAPS); | |
178 }; | |
6854
fb19af007ffc
7189254: Change makefiles for more flexibility to override defaults
jprovino
parents:
6202
diff
changeset
|
179 #endif // INCLUDE_SERVICES |
4773 | 180 |
7956 | 181 // See also: inspectheap in attachListener.cpp |
4773 | 182 class ClassHistogramDCmd : public DCmdWithParser { |
183 protected: | |
184 DCmdArgument<bool> _all; | |
185 public: | |
186 ClassHistogramDCmd(outputStream* output, bool heap); | |
187 static const char* name() { | |
188 return "GC.class_histogram"; | |
189 } | |
190 static const char* description() { | |
191 return "Provide statistics about the Java heap usage."; | |
192 } | |
193 static const char* impact() { | |
194 return "High: Depends on Java heap size and content."; | |
195 } | |
196 static int num_arguments(); | |
197 virtual void execute(TRAPS); | |
198 }; | |
199 | |
7956 | 200 class ClassStatsDCmd : public DCmdWithParser { |
201 protected: | |
202 DCmdArgument<bool> _all; | |
203 DCmdArgument<bool> _csv; | |
204 DCmdArgument<bool> _help; | |
205 DCmdArgument<char*> _columns; | |
206 public: | |
207 ClassStatsDCmd(outputStream* output, bool heap); | |
208 static const char* name() { | |
209 return "GC.class_stats"; | |
210 } | |
211 static const char* description() { | |
212 return "Provide statistics about Java class meta data. Requires -XX:+UnlockDiagnosticVMOptions."; | |
213 } | |
214 static const char* impact() { | |
215 return "High: Depends on Java heap size and content."; | |
216 } | |
217 static int num_arguments(); | |
218 virtual void execute(TRAPS); | |
219 }; | |
220 | |
4773 | 221 // See also: thread_dump in attachListener.cpp |
222 class ThreadDumpDCmd : public DCmdWithParser { | |
223 protected: | |
224 DCmdArgument<bool> _locks; | |
225 public: | |
226 ThreadDumpDCmd(outputStream* output, bool heap); | |
227 static const char* name() { return "Thread.print"; } | |
228 static const char* description() { | |
229 return "Print all threads with stacktraces."; | |
230 } | |
231 static const char* impact() { | |
232 return "Medium: Depends on the number of threads."; | |
233 } | |
234 static int num_arguments(); | |
235 virtual void execute(TRAPS); | |
4133 | 236 }; |
237 | |
5895
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
238 // Enhanced JMX Agent support |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
239 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
240 class JMXStartRemoteDCmd : public DCmdWithParser { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
241 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
242 // Explicitly list all properties that could be |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
243 // passed to Agent.startRemoteManagementAgent() |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
244 // com.sun.management is omitted |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
245 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
246 DCmdArgument<char *> _config_file; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
247 DCmdArgument<char *> _jmxremote_port; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
248 DCmdArgument<char *> _jmxremote_rmi_port; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
249 DCmdArgument<char *> _jmxremote_ssl; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
250 DCmdArgument<char *> _jmxremote_registry_ssl; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
251 DCmdArgument<char *> _jmxremote_authenticate; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
252 DCmdArgument<char *> _jmxremote_password_file; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
253 DCmdArgument<char *> _jmxremote_access_file; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
254 DCmdArgument<char *> _jmxremote_login_config; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
255 DCmdArgument<char *> _jmxremote_ssl_enabled_cipher_suites; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
256 DCmdArgument<char *> _jmxremote_ssl_enabled_protocols; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
257 DCmdArgument<char *> _jmxremote_ssl_need_client_auth; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
258 DCmdArgument<char *> _jmxremote_ssl_config_file; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
259 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
260 public: |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
261 JMXStartRemoteDCmd(outputStream *output, bool heap_allocated); |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
262 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
263 static const char *name() { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
264 return "ManagementAgent.start"; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
265 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
266 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
267 static const char *description() { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
268 return "Start remote management agent."; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
269 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
270 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
271 static int num_arguments(); |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
272 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
273 virtual void execute(TRAPS); |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
274 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
275 }; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
276 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
277 class JMXStartLocalDCmd : public DCmd { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
278 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
279 // Explicitly request start of local agent, |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
280 // it will not be started by start dcmd |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
281 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
282 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
283 public: |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
284 JMXStartLocalDCmd(outputStream *output, bool heap_allocated); |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
285 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
286 static const char *name() { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
287 return "ManagementAgent.start_local"; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
288 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
289 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
290 static const char *description() { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
291 return "Start local management agent."; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
292 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
293 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
294 virtual void execute(TRAPS); |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
295 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
296 }; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
297 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
298 class JMXStopRemoteDCmd : public DCmd { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
299 public: |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
300 JMXStopRemoteDCmd(outputStream *output, bool heap_allocated) : |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
301 DCmd(output, heap_allocated) { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
302 // Do Nothing |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
303 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
304 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
305 static const char *name() { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
306 return "ManagementAgent.stop"; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
307 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
308 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
309 static const char *description() { |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
310 return "Stop remote management agent."; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
311 } |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
312 |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
313 virtual void execute(TRAPS); |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
314 }; |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4851
diff
changeset
|
315 |
4133 | 316 #endif // SHARE_VM_SERVICES_DIAGNOSTICCOMMAND_HPP |