JVM监控工具VisualVM的使用
VisualVM是jvm的可视化监控工具
?
下载地址:http://visualvm.java.net/download.html
?
监控本地jvm很简单,这里不详细说了。
监控远程jvm的方法有2种
一、远程服务器启动jstatd守护进程
./jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.0.50 -J-Djava.rmi.server.logCalls=true -p 1011
?
?
1、 在JDK/bin下新建一文本文件, 名称 jstatd.all.policy
??? 内容如下:
??? grant codebase "file:${java.home}/../lib/tools.jar" {
?????? permission java.security.AllPermission;
??? };
2、 运行 jstatd -J-Djava.security.policy=jstatd.all.policy
????? 若需要指定端口, 请使用 -p 1011
??????指定守护进程监听的ip(默认是127.0.0.1),请使用-J-Djava.rmi.server.hostname=192.168.0.50
????? 查看日志,请使用-J-Djava.rmi.server.logCalls=true
????? 另外注意防火墙,需要使用1011之外的其他端口
3、?在终端启动VisualVM.
?
二、JMX方式
1、JAVA_OPTS="Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmx
remote.ssl=false -Dcom.sun.management.jmxremote.authenticate=true -Djava.rmi.server.hostname=192.168.0.50"
?
2、鉴权方法
jdk/jre/lib/management/jmxremote.access? 定义了2种权限,读写和只读
?
monitorRole?? readonly表示只能监控
controlRole?? readwrite表示可以修改jmx的各项配置
可以添加任意用户,如:
admin readwrite
?
jdk/jre/lib/management/jmxremote.password
定义了jmxremote.access中的用户名的密码,如:
admin 111111
?
?
三、VisaulVM插件
菜单:工具->插件->可用插件(下载)
现在要下载的插件安装即可。几个有用的插件:
1、Visaul GC,可以参考详细的GC信息和内存使用情况,很详细哦。不过远程访问不支持JMX方式,必须用jstatd方式
?2、Visaul MBeans,jmx管理界面,可以管理应用中个所有mbean。如果使用spring,可以通过spring的jmx整合,将bean暴露出来,即可实时的修改各项应用配置。
3、Profile,cpu和内存性能分析,可以按照包名过滤不需要监控的类
3、BTrace,可以在不宕机的情况下调试代码。在visualVM上可以右键选中Trace Applicationg...打开BTrace窗口(只支持本地jvm),下面这个是查看某个方法的执行时间的示例:
/* BTrace Script Template */
import com.sun.btrace.annotations.*;
import static com.sun.btrace.BTraceUtils.*;
@BTrace
public class TracingScript {
??? @TLS?
??? private static long startTime = 0;
???
??? @OnMethod(clazz="com.aspire.pams3.verify.audit.action.audit.AuditAction", method="getAuditContent")
??? public static void startMethod() {
??????? startTime = timeMillis();
??? }
??? @OnMethod(clazz="com.aspire.pams3.verify.audit.action.audit.AuditAction", method="getAuditContent", location=@Location(Kind.RETURN))
??? public static void endMethod() {
??????? print(strcat(strcat(name(probeClass()), "."), probeMethod()));
??????????? print(" [");
??????????? print(strcat("Time taken : ", str(timeMillis() - startTime)));
??????????? println("]");
??? }
}
如果需要在远程服务器执行,需要下载http://kenai.com/projects/btrace/downloads/directory/releases
将上面的代码保存为TracingScript.java
执行./btrace <pid> TracingScript.java
4、OQL,对象查询语言